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

Mary-Kate Olsen
Lepaskan: 2024-10-31 22:59:29
asal
993 orang telah melayarinya

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

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

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!

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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!