Rumah >pangkalan data >tutorial mysql >Bagaimana Menjana Siri Tarikh Tanpa Jadual atau Pembolehubah Sementara?

Bagaimana Menjana Siri Tarikh Tanpa Jadual atau Pembolehubah Sementara?

Barbara Streisand
Barbara Streisandasal
2024-12-06 12:22:12762semak imbas

How to Generate a Date Series Without Temporary Tables or Variables?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn