Heim > Datenbank > MySQL-Tutorial > Wie berechnet man genaue Monatsunterschiede in MySQL?

Wie berechnet man genaue Monatsunterschiede in MySQL?

Linda Hamilton
Freigeben: 2024-11-25 14:14:11
Original
526 Leute haben es durchsucht

How to Calculate Precise Month Differences in MySQL?

Präzise Monatsdifferenzberechnung in MySQL

MySQL bietet eine unverzichtbare Funktion, TIMESTAMPDIFF(), um die Anzahl der Monate zwischen zwei Daten zu berechnen. Es beseitigt Komplikationen, die mit unterschiedlichen Monatslängen und Schaltjahren verbunden sind.

SELECT TIMESTAMPDIFF(MONTH, '2012-03-08', '2012-08-01');
-- Outputs: 4
Nach dem Login kopieren

Präzisionsverbesserung

Für eine höhere Präzision kann ein komplexerer Ansatz verwendet werden:

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
  )
Nach dem Login kopieren

Diese Formel erhöht die Präzision, indem sie die verbleibenden Tage (nach Monatsdifferenz) als Bruchteil von a berechnet Monat.

Beispiele

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
Nach dem Login kopieren

Dieses Ergebnis zeigt an, dass zwischen den beiden Daten ein Monat und etwa 23,33 % eines Monatsunterschieds liegen.

Das obige ist der detaillierte Inhalt vonWie berechnet man genaue Monatsunterschiede in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage