Rumah >pangkalan data >tutorial mysql >Bagaimana Menjana Siri Tarikh Tanpa Jadual atau Pembolehubah Sementara?
Menjana Siri Tarikh tanpa Jadual atau Pembolehubah Sementara
Walaupun ketersediaan jadual dengan julat tarikh yang dipratentukan, pendekatan ini dianggap sebagai suboptimum. Bagaimanakah kita boleh menjana satu siri tarikh dalam selang waktu tertentu tanpa menggunakan jadual sementara atau manipulasi pembolehubah?
Pertimbangkan senario berikut: aplikasi anda memerlukan laporan yang mengembalikan baris untuk setiap tarikh, tanpa mengira data yang tersedia. Untuk mencapai matlamat ini, pertanyaan mudah boleh dibina:
select dates.date, sum(sales.amount) from <series of dates between X and Y> dates left join sales on date(sales.created) = dates.date group by 1
Untuk mengelakkan daripada membuat jadual dengan banyak tarikh, penyelesaian alternatif disyorkan:
select * from (select adddate('1970-01-01',t4*10000 + t3*1000 + t2*100 + t1*10 + t0) gen_date from (select 0 t0 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0, (select 0 t1 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1, (select 0 t2 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2, (select 0 t3 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3, (select 0 t4 union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) v where gen_date between '2017-01-01' and '2017-12-31'
Pertanyaan ini menjana satu siri dengan berkesan tarikh dalam julat yang ditentukan tanpa membuat jadual berasingan atau menetapkan pembolehubah.
Atas ialah kandungan terperinci Bagaimana Menjana Siri Tarikh Tanpa Jadual atau Pembolehubah Sementara?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!