Bei der Arbeit mit Datums- und Zeitdaten in MySQL ist es häufig erforderlich, Daten auszuwählen, die in einen bestimmten Datumsbereich fallen . Wenn Sie jedoch die Spalte „created_at“ als Datums-/Uhrzeitwert verwenden, ist die Standardinterpretation für kurze Daten Mitternacht.
Problem:
Es kann vorkommen, dass eine Abfrage wie Im Folgenden wird keine Zeile zurückgegeben, obwohl der Zeitstempel „created_at“ der Zeile innerhalb des angegebenen Datums liegt Bereich:
SELECT `users`.* FROM `users` WHERE created_at >= '2011-12-01' AND created_at <= '2011-12-06'
Lösung:
Das Problem besteht darin, dass die Abfrage tatsächlich Daten mit einem Bereich von „2011-12-01 00:00:00“ auswählt ' bis '2011-12-06 00:00:00'. Um dies zu beheben, gibt es mehrere Ansätze:
SELECT `users`.* FROM `users` WHERE created_at >= '2011-12-01' AND created_at <= '2011-12-07'
SELECT `users`.* FROM `users` WHERE created_at >= '2011-12-01' AND created_at <= DATE_ADD('2011-12-01', INTERVAL 7 DAY)
SELECT `users`.* FROM `users` WHERE created_at BETWEEN('2011-12-01', DATE_ADD('2011-12-01', INTERVAL 7 DAY))
Durch die Verwendung eines dieser Ansätze werden Daten korrekt ausgewählt, die in den angegebenen Bereich fallen Datumsbereich, einschließlich Zeilen mit „created_at“-Zeitstempeln wie „2011-12-06“. 10:45:36'.
Das obige ist der detaillierte Inhalt vonWie wähle ich Daten zwischen zwei Daten in MySQL richtig aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!