Pengiraan Perbezaan Bulan yang Tepat dalam MySQL
MySQL menyediakan fungsi yang sangat diperlukan, TIMESTAMPDIFF(), untuk mengira bilangan bulan antara dua tarikh. Ia menghapuskan komplikasi yang berkaitan dengan tempoh bulan dan tahun lompat yang berbeza-beza.
SELECT TIMESTAMPDIFF(MONTH, '2012-03-08', '2012-08-01'); -- Outputs: 4
Peningkatan Ketepatan
Untuk ketepatan yang lebih tinggi, pendekatan yang lebih rumit boleh digunakan:
SELECT TIMESTAMPDIFF(MONTH, startdate, enddate) + DATEDIFF( enddate, startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) MONTH ) / DATEDIFF( startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) + 1 MONTH, startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) MONTH )
Formula ini menambah ketepatan dengan mengira baki hari (selepas perbezaan bulan) sebagai pecahan sebulan.
Contoh
WITH startdate AS '2012-03-08', enddate AS '2012-04-15' SELECT TIMESTAMPDIFF(MONTH, startdate, enddate) + DATEDIFF( enddate, startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) MONTH ) / DATEDIFF( startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) + 1 MONTH, startdate + INTERVAL TIMESTAMPDIFF(MONTH, startdate, enddate) MONTH ); -- Outputs: 1.2333
Keputusan ini menunjukkan terdapat perbezaan 1 bulan dan kira-kira 23.33% sebulan antara kedua-dua tarikh.
Atas ialah kandungan terperinci Bagaimana untuk Mengira Perbezaan Bulan Tepat dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!