sql >> データベース >  >> RDS >> PostgreSQL

PostgreSQLカスタム週番号-2月1日を含む最初の週

    date_trunc() 前の月曜日に切り捨てます 。入力に2日(土と月の差)を加算し、出力から2日を減算することで、引き続き使用できます。完璧に機能します。

    このクエリは、目的の出力を正確に生成します。 :

    SELECT d::date                     AS "Calendar_Date"
         , EXTRACT('WEEK' FROM d)::int AS "Week_No"
         , to_char(d, 'Dy')            AS "WeekDay_No"
         , base_nr + (rn::int - 1) / 7 AS "Customized_Week_No"
    FROM  (
       SELECT date_trunc('week', feb3) - interval '2 days' AS day1 -- subtract 2 days
            , EXTRACT('year' FROM feb3)::int * 100 + 1     AS base_nr
       FROM  (SELECT timestamp '2015-02-03') input(feb3)           -- add 2 days, so Feb 3 (!)
       ) t, generate_series (day1
                           , day1 + interval '1 year - 1 day' 
                           , interval '1 day') WITH ORDINALITY AS d(d, rn);
    

    それぞれの年の2月3日を入力してください:timestamp '2015-02-03'




    1. MySQLレーベンシュタイン

    2. OracleDatabaseで仮想索引を使用する方法

    3. 無向グラフのすべての接続されたサブグラフを見つける方法

    4. MySQLで破損したInnoDBテーブルを修復するための最良の方法