Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mengira Perbezaan Bulan Tepat dalam MySQL?

Bagaimana untuk Mengira Perbezaan Bulan Tepat dalam MySQL?

Linda Hamilton
Linda Hamiltonasal
2024-11-25 14:14:11572semak imbas

How to Calculate Precise Month Differences in MySQL?

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!

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