Menjana Bulan dalam Julat Tarikh Tertentu, Termasuk Nilai Kosong
Soalan:
Dalam MySQL , bagaimanakah saya boleh menjana senarai semua bulan dalam julat tarikh tertentu, walaupun tiada nilai wujud untuk beberapa bulan?
Jawapan:
Untuk mencapai ini, buat jadual berasingan yang mengandungi semua bulan yang mungkin, seperti:
CREATE TABLE dateTable ( myDate DATE NOT NULL, myYear SMALLINT NOT NULL, myMonth TINYINT UNSIGNED NOT NULL );
Isi jadual ini dengan semua bulan yang mungkin anda temui dalam data anda.
Kemudian, gunakan LEFT JOIN untuk menggabungkan asal anda jadual, myTable, dengan dateTable:
SELECT DT.myYear, DT.myMonth, AVG(myTable.value1) AS avg_value_1, AVG(myTable.value2) AS avg_value_2 FROM dateTable AS DT LEFT JOIN myTable ON DT.myDate = myTable.save_date WHERE DT.myDate BETWEEN '2009-01-01' AND '2009-07-01' GROUP BY DT.myYear, DT.myMonth
Ini akan mendapatkan semula nilai purata untuk semua bulan dalam julat yang ditentukan, termasuk bulan tanpa nilai dalam myTable. LEFT JOIN memastikan bahawa nilai kosong disertakan dengan memadankan DT.myDate kepada semua baris dalam myTable, tidak kira sama ada mereka mempunyai nilai yang sepadan.
Anda boleh menyesuaikan lagi output dengan melaraskan klausa GROUP BY kepada hasil kumpulan dengan tempoh masa yang diingini, seperti suku tahun kewangan atau hari dalam seminggu. Pendekatan ini menyediakan cara yang mudah dan cekap untuk menjana laporan komprehensif dengan liputan bulan lengkap.
Atas ialah kandungan terperinci Bagaimana untuk Menjana Bulan dalam Julat Tarikh Tertentu dalam MySQL, Termasuk Nilai Kosong?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!