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
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 )
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
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!