Bagaimana Mendapatkan Rekod Bijak Bulanan daripada Pangkalan Data Walaupun Data Tiada?

Patricia Arquette
Lepaskan: 2024-11-06 05:55:02
asal
777 orang telah melayarinya

How to Get Month-Wise Records from a Database Even When Data is Missing?

Mendapatkan Rekod Bulanan dalam Pangkalan Data, Walaupun Data Tiada

Dalam sistem pengurusan pangkalan data, selalunya perlu untuk mengekstrak rekod mengikut bulan daripada jadual. Walau bagaimanapun, cabaran timbul apabila terdapat titik data yang hilang untuk bulan tertentu. Artikel ini menangani isu ini, membentangkan penyelesaian untuk menjana senarai lengkap bulan dan mendapatkan semula data yang sepadan, walaupun nilai tiada.

Pertanyaan asal yang anda berikan:

SELECT COUNT( `userID` ) AS total, DATE_FORMAT( `userRegistredDate` , '%b' ) AS MONTH , YEAR( `userRegistredDate` ) AS year
FROM `users`
GROUP BY DATE_FORMAT( FROM_UNIXTIME( `userRegistredDate` , '%b' ) )
Salin selepas log masuk

menyediakan output yang dikehendaki, tetapi hanya selama berbulan-bulan dengan data sedia ada. Untuk mengendalikan bulan yang hilang, kami menggunakan jadual dengan senarai bulan yang lengkap dan menyertainya dengan jadual pengguna:

SELECT COUNT(u.userID) AS total, m.month
FROM (
    SELECT 'Jan' AS MONTH
    UNION SELECT 'Feb' AS MONTH
    UNION SELECT 'Mar' AS MONTH
    UNION SELECT 'Apr' AS MONTH
    UNION SELECT 'May' AS MONTH
    UNION SELECT 'Jun' AS MONTH
    UNION SELECT 'Jul' AS MONTH
    UNION SELECT 'Aug' AS MONTH
    UNION SELECT 'Sep' AS MONTH
    UNION SELECT 'Oct' AS MONTH
    UNION SELECT 'Nov' AS MONTH
    UNION SELECT 'Dec' AS MONTH
) AS m
LEFT JOIN users u 
ON MONTH(STR_TO_DATE(CONCAT(m.month, ' 2013'),'%M %Y')) = MONTH(u.userRegistredDate)
AND YEAR(u.userRegistredDate) = '2013'
GROUP BY m.month
ORDER BY 1+1;
Salin selepas log masuk

Jadual kesatuan ini memastikan semua bulan diwakili, membolehkan set hasil lengkap. Pendekatan alternatif yang memudahkan pertanyaan dibentangkan di bawah:

SELECT COUNT(u.userID) AS total, DATE_FORMAT(merge_date,'%b') AS month, YEAR(m.merge_date) AS year
FROM (
    SELECT '2013-01-01' AS merge_date
    UNION SELECT '2013-02-01' AS merge_date
    UNION SELECT '2013-03-01' AS merge_date
    UNION SELECT '2013-04-01' AS merge_date
    UNION SELECT '2013-05-01' AS merge_date
    UNION SELECT '2013-06-01' AS merge_date
    UNION SELECT '2013-07-01' AS merge_date
    UNION SELECT '2013-08-01' AS merge_date
    UNION SELECT '2013-09-01' AS merge_date
    UNION SELECT '2013-10-01' AS merge_date
    UNION SELECT '2013-11-01' AS merge_date
    UNION SELECT '2013-12-01' AS merge_date
) AS m
LEFT JOIN users u 
ON MONTH(m.merge_date) = MONTH(u.userRegistredDate)
AND YEAR(m.merge_date) = YEAR(u.userRegistredDate)
GROUP BY m.merge_date
ORDER BY 1+1;
Salin selepas log masuk

Pertanyaan yang diubah suai ini menggunakan gabungan tarikh untuk mewakili julat bulan yang lengkap. Kedua-dua kaedah mencapai matlamat untuk menjana rekod mengikut bulan, walaupun tanpa data untuk semua bulan.

Atas ialah kandungan terperinci Bagaimana Mendapatkan Rekod Bijak Bulanan daripada Pangkalan Data Walaupun Data Tiada?. 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