Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menjana Bulan dalam Julat Tarikh Tertentu dalam MySQL, Termasuk Nilai Kosong?

Bagaimana untuk Menjana Bulan dalam Julat Tarikh Tertentu dalam MySQL, Termasuk Nilai Kosong?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-31 22:59:291107semak imbas

How to Generate Months within a Specific Date Range in MySQL, Including Empty Values?

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!

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