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
Linda Hamiltonasal
2024-12-23 04:57:37411semak imbas

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        |
+-------------------+

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                                        |
+---------------------------------------------------+

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                                                                       |
+----------------------------------------------------------------------------------+

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';

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!

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