Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Mencipta Objek DATE dalam MySQL dari Medan Hari, Bulan dan Tahun Berasingan?

Bagaimanakah Saya Boleh Mencipta Objek DATE dalam MySQL dari Medan Hari, Bulan dan Tahun Berasingan?

Linda Hamilton
Lepaskan: 2024-12-23 04:57:37
asal
370 orang telah melayarinya

How Can I Create a DATE Object in MySQL from Separate Day, Month, and Year Fields?

Buat Objek Tarikh daripada Medan Hari, Bulan dan Tahun dalam MySQL

Dalam skema pangkalan data dengan jadual 'tarikh' yang mengandungi berasingan medan untuk 'hari,' 'bulan' dan 'tahun,' menjadi perlu untuk mencipta objek tarikh untuk perbandingan. Artikel ini menggariskan penyelesaian untuk membina objek tarikh daripada nilai integer ini.

Menggunakan fungsi MAKEDATE() dan DATE_ADD(), DATETIME boleh dibuat daripada komponen tahun, bulan dan hari. MAKEDATE() menjana DATETIME yang mewakili hari pertama tahun yang ditentukan. Selepas itu, DATE_ADD() boleh digunakan untuk menambah nilai bulan dan hari.

Contohnya:

SELECT MAKEDATE(2013, 1);
+-------------------+
| MAKEDATE(2013, 1) |
+-------------------+
| 2013-01-01        |
+-------------------+
Salin selepas log masuk

Untuk memasukkan nilai bulan dan hari:

SELECT DATE_ADD(MAKEDATE(2013, 1), INTERVAL (3)-1 MONTH);
+---------------------------------------------------+
| DATE_ADD(MAKEDATE(2013, 1), INTERVAL (3)-1 MONTH) |
+---------------------------------------------------+
| 2013-03-01                                        |
+---------------------------------------------------+
Salin selepas log masuk

Menggabungkan berbilang panggilan DATE_ADD() membolehkan tarikh yang tepat pembinaan:

SELECT DATE_ADD(DATE_ADD(MAKEDATE(2013, 1), INTERVAL (3)-1 MONTH), INTERVAL (11)-1 DAY);
| DATE_ADD(DATE_ADD(MAKEDATE(2013, 1), INTERVAL (3)-1 MONTH), INTERVAL (11)-1 DAY) |
+----------------------------------------------------------------------------------+
| 2013-03-11                                                                       |
+----------------------------------------------------------------------------------+
Salin selepas log masuk

Untuk melaksanakan pertanyaan julat tarikh menggunakan teknik ini:

SELECT * FROM `date`
WHERE DATE_ADD(DATE_ADD(MAKEDATE(year, 1), INTERVAL (month)-1 MONTH), INTERVAL (day)-1 DAY)
BETWEEN '2013-01-01' AND '2014-01-01';
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencipta Objek DATE dalam MySQL dari Medan Hari, Bulan dan Tahun Berasingan?. 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