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!