PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Niestandardowy numer tygodnia PostgreSQL - pierwszy tydzień zawierający 1 lutego

date_trunc() zostanie skrócony do poprzedniego poniedziałku . Nadal możesz z niego korzystać, dodając 2 dni do wejścia (różnica między sob i pon), a następnie odejmij 2 dni od wyniku. Działa doskonale.

To zapytanie daje żądany wynik dokładnie :

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

Wystarczy podać 3 lutego odpowiedniego roku:timestamp '2015-02-03' .




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Dołącz jeden do wielu i pobierz pojedynczy wynik

  2. Wdrażanie PostgreSQL w kontenerze Docker

  3. PostgreSQL:ograniczenie, które wpływa na wiele tabel

  4. PostgreSQL 10 w systemie Linux — LC_COLLATE locale en_US.utf-8 niepoprawne

  5. Zalogowany jako postgres, ale pojawia się błąd createuser:tworzenie nowej roli nie powiodło się:BŁĄD:musisz być superużytkownikiem, aby utworzyć superużytkowników