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

Bagaimana untuk Mengira Perbezaan Bulan Tepat dalam MySQL?

Linda Hamilton
Lepaskan: 2024-11-25 14:14:11
asal
510 orang telah melayarinya

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
Salin selepas log masuk

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
  )
Salin selepas log masuk

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
Salin selepas log masuk

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!

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