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

MySQL:レコードが存在しない場合でも、範囲内のすべての日付を選択します

    残りの部分を理解していただければ幸いです。

    select  * from (
    select date_add('2003-01-01 00:00:00.000', INTERVAL n5.num*10000+n4.num*1000+n3.num*100+n2.num*10+n1.num DAY ) as date from
    (select 0 as num
       union all select 1
       union all select 2
       union all select 3
       union all select 4
       union all select 5
       union all select 6
       union all select 7
       union all select 8
       union all select 9) n1,
    (select 0 as num
       union all select 1
       union all select 2
       union all select 3
       union all select 4
       union all select 5
       union all select 6
       union all select 7
       union all select 8
       union all select 9) n2,
    (select 0 as num
       union all select 1
       union all select 2
       union all select 3
       union all select 4
       union all select 5
       union all select 6
       union all select 7
       union all select 8
       union all select 9) n3,
    (select 0 as num
       union all select 1
       union all select 2
       union all select 3
       union all select 4
       union all select 5
       union all select 6
       union all select 7
       union all select 8
       union all select 9) n4,
    (select 0 as num
       union all select 1
       union all select 2
       union all select 3
       union all select 4
       union all select 5
       union all select 6
       union all select 7
       union all select 8
       union all select 9) n5
    ) a
    where date >'2011-01-02 00:00:00.000' and date < NOW()
    order by date
    

    select n3.num*100+n2.num*10+n1.num as date
    

    0からmax(n3)* 100 + max(n2)* 10 + max(n1)

    までの数値の列が表示されます

    ここでは最大n3が3であるため、SELECTは399に加えて、0-> 400レコード(カレンダーの日付)を返します。

    たとえば、min(date)からnow()に制限することで、動的カレンダーを調整できます。



    1. MySQLバージョンを確認する方法

    2. スタートレックの3Dチェスデータモデル

    3. MariaDB FLOOR()とTRUNCATE()

    4. SQL Server Management Studio(SSMS)でクエリ結果を.csvまたはタブ区切りファイルにエクスポートする方法-SQL Server/TSQLチュートリアルパート23