Abrufen von Datensätzen innerhalb eines Zeitraums von 30 Tagen in MySQL
Benutzer stoßen häufig auf Schwierigkeiten, wenn sie versuchen, Datensätze abzurufen, die innerhalb eines Zeitraums zu einer MySQL-Datenbank hinzugefügt wurden bestimmten Datumsbereich, insbesondere bei Verwendung der Datumsformatierung. Dieser Artikel befasst sich mit dieser Herausforderung, indem er eine umfassende Lösung zum Abrufen von Datensätzen zwischen heute und den letzten 30 Tagen bereitstellt und dabei die richtige Datumsformatierung für Anzeigezwecke gewährleistet.
Bei der ursprünglichen Abfrage in der Frage ist ein Problem aufgetreten, bei dem die Einschränkung fehlgeschlagen ist Die Auswahl wurde auf die letzten 30 Tage beschränkt und stattdessen alle Datensätze abgerufen. Um dies zu korrigieren, ist es wichtig, die Funktion DATE_FORMAT innerhalb der SELECT-Klausel und nicht in der WHERE-Klausel anzuwenden. Die korrigierte Abfrage lautet wie folgt:
SELECT DATE_FORMAT(create_date, '%m/%d/%Y') FROM mytable WHERE create_date BETWEEN CURDATE() - INTERVAL 30 DAY AND CURDATE()
Es ist wichtig zu beachten, dass CURDATE() nur den Datumsteil abruft, ohne die Uhrzeit. Wenn Ihre Spalte „create_date“ Daten als DATETIME mit einer Zeitkomponente ungleich Null speichert, gibt diese Abfrage möglicherweise nicht die heutigen Datensätze zurück.
Um dieses Problem zu beheben, sollten Sie stattdessen die Verwendung von NOW() in Betracht ziehen:
SELECT DATE_FORMAT(create_date, '%m/%d/%Y') FROM mytable WHERE create_date BETWEEN NOW() - INTERVAL 30 DAY AND NOW()
Durch diese Änderung wird sichergestellt, dass die Abfrage Datensätze zurückgibt, die innerhalb der letzten 30 Tage hinzugefügt wurden, einschließlich derjenigen, die am aktuellen Tag mit einer beliebigen Zeitkomponente hinzugefügt wurden.
Das obige ist der detaillierte Inhalt vonWie kann ich MySQL-Datensätze der letzten 30 Tage effizient abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!