Mengambil Data Antara Tarikh: Mengisi Rekod Kosong
Dalam MySQL, memilih data dalam julat tarikh yang ditentukan biasanya dicapai menggunakan operator BETWEEN. Walau bagaimanapun, pendekatan ini mungkin menyebabkan tarikh hilang apabila tiada data hadir. Untuk menyelesaikan masalah ini, teknik yang melibatkan 'jadual kalendar' digunakan.
Konsep jadual kalendar adalah untuk mencipta jadual yang mengandungi jujukan tarikh dalam julat yang dikehendaki. Ini dicapai menggunakan kod berikut:
CREATE TABLE ints (i INTEGER); INSERT INTO ints VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9);
Jadual ini menyediakan julat nombor dari 0 hingga 9. Untuk menjana jadual kalendar, kami menggabungkan int dengan dirinya sendiri beberapa kali untuk membuat senarai selang tarikh:
SELECT '2009-06-25' + INTERVAL a.i * 10 + b.i DAY as date FROM ints a JOIN ints b ORDER BY a.i * 10 + b.i
Hasilnya ialah jadual dengan urutan tarikh dari '2009-06-25' hingga '2009-07-04'. Untuk mendapatkan semula data, kami meninggalkan menyertai jadual kalendar dengan jadual asal:
SELECT cal.date, tbl.data FROM ( SELECT '2009-06-25' + INTERVAL a.i * 10 + b.i DAY as date FROM ints a JOIN ints b ORDER BY a.i * 10 + b.i ) cal LEFT JOIN tbl ON cal.date = tbl.date WHERE cal.date BETWEEN '2009-06-25' AND '2009-07-01';
Pertanyaan ini mengembalikan data untuk semua tarikh antara '2009-06-25' dan '2009-07-01', termasuk baris tanpa data yang diisi dengan '0'.
Atas ialah kandungan terperinci Bagaimana untuk Mengisi Tarikh Hilang dalam Pengambilan Data MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!