Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mengisi Tarikh Hilang dalam Pengambilan Data MySQL?

Bagaimana untuk Mengisi Tarikh Hilang dalam Pengambilan Data MySQL?

Barbara Streisand
Lepaskan: 2024-12-12 19:09:11
asal
425 orang telah melayarinya

How to Populate Missing Dates in MySQL Data Retrievals?

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);
Salin selepas log masuk

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
Salin selepas log masuk

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';
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan