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

MySQL:Vyberte všechna data v rozsahu, i když nejsou k dispozici žádné záznamy

Doufám, že zbytek zjistíte.

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

S

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

získáte sloupec s čísly od 0 do max(n3)*100+max(n2)*10+max(n1)

Protože zde máme max n3 jako 3, SELECT vrátí 399 plus 0 -> 400 záznamů (dat v kalendáři).

Svůj dynamický kalendář můžete vyladit tak, že jej omezíte, například od min(datum) musíte do teď().



  1. Přidejte sloupec s výchozí hodnotou do existující tabulky na SQL Server

  2. Spustit odložený trigger pouze jednou na řádek v PostgreSQL

  3. Jak srovnávat výkon MySQL a MariaDB pomocí SysBench

  4. Nejčastější dotazy na primární klíč v Oracle s příklady