sql >> Databáze >  >> RDS >> Mysql

MySQL převést YEARWEEK na datum

Je třeba si dát pozor, aby byl roční týden v očekávaném „režimu“. (Viz https://dev .mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_week )

Formátování použité v STR_TO_DATE by se mělo shodovat. (Viz https:/ /dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_date-format )

např. Pokud používáte režim 2 (1-53, týden 1 je první týden s nedělí, týdny začínají v neděli)

SELECT STR_TO_DATE(CONCAT('201439',' Sunday'), '%X%V %W');

např. Pokud používáte režim 3 (podle ISO-8601), (1-53, týden 1 je první týden se 4 nebo více dny počínaje pondělím), musíte použít verzi s malými písmeny.

SELECT STR_TO_DATE(CONCAT('201439',' Monday'), '%x%v %W');

Jeden by tedy dostal následující (2014-09-28 je neděle):

SELECT yearweek('2014-09-28', 2);
201439
SELECT yearweek('2014-09-28', 3);
201439
SELECT yearweek('2014-09-29', 2);
201439
SELECT yearweek('2014-09-29', 3);
201440

pak

SELECT STR_TO_DATE(CONCAT('201439',' Sunday'), '%X%V %W'); -- mode 2
2014-09-28
SELECT STR_TO_DATE(CONCAT('201439',' Monday'), '%x%v %W'); -- mode 3 
2014-09-22
SELECT STR_TO_DATE(CONCAT('201440',' Monday'), '%x%v %W'); -- mode 3
2014-09-29


  1. Jak zkontrolovat, zda je pole v MySQL prázdné nebo prázdné?

  2. Oracle odstranění řádků z více tabulek

  3. Dotaz na hodnocení skupin PHP MYSQL

  4. Připravené příkazy MySQL