sql >> Databáze >  >> RDS >> PostgreSQL

PostgreSQL vlastní číslo týdne – první týden obsahující 1. února

date_trunc() zkrátí na předchozí pondělí . Stále jej můžete použít tak, že ke vstupu přičtete 2 dny (rozdíl mezi So a Po), poté 2 dny odečtete od výstupu. Funguje perfektně.

Tento dotaz vytvoří požadovaný výstup přesně :

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);

Stačí zadat 3. února příslušného roku:timestamp '2015-02-03' .




  1. Jak odinstalovat Mysql Shell na MacOS

  2. psycopg2.OperationalError:FATAL:nepodporovaný frontend protokol 1234.5679:server podporuje 2.0 až 3.0

  3. Jak sloučit dva modely django (tabulky) do jednoho modelu (tabulky)

  4. Proč Postgres Allowing Me Have Columns není ve skupině podle?