Extraire les données des sept derniers jours avec SQL
Ce guide montre comment récupérer les données de la semaine dernière à l'aide d'une requête SQL, en définissant la semaine comme commençant le dimanche. Disons que vous disposez d'un tableau avec une colonne « date » et d'autres données pertinentes. L'objectif est de sélectionner les candidatures des sept derniers jours.
Exemple de tableau :
Considérez un tableau avec les exemples de données suivants :
id | date |
---|---|
2 | 2011-05-14 09:17:25 |
5 | 2011-05-16 09:17:25 |
6 | 2011-05-17 09:17:25 |
8 | 2011-05-20 09:17:25 |
15 | 2011-05-22 09:17:25 |
L'objectif est d'extraire les id
valeurs 5, 6 et 8, représentant les données de la semaine précédente.
Requête SQL :
La requête MySQL suivante permet d'atteindre cet objectif :
<code class="language-sql">SELECT id FROM tbname WHERE date BETWEEN DATE_SUB(NOW(), INTERVAL 7 DAY) AND NOW();</code>
Explication :
Cette requête utilise l'opérateur BETWEEN
pour filtrer les enregistrements dont la « date » se situe dans une période spécifique. DATE_SUB(NOW(), INTERVAL 7 DAY)
calcule la date et l'heure sept jours avant le moment actuel (NOW()
). La clause BETWEEN
sélectionne ensuite les entrées entre cette date calculée et la date et l'heure actuelles.
Résultat :
La requête renvoie ce qui suit :
id |
---|
5 |
6 |
8 |
Ces id
valeurs reflètent avec précision les entrées de données de la semaine dernière. Notez que cette requête prend en compte les sept derniers jours quel que soit le jour de la semaine. Pour une définition de semaine plus complexe (par exemple, commençant le dimanche), une manipulation de date plus sophistiquée peut être nécessaire, impliquant potentiellement la fonction DAYOFWEEK()
ou similaire.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!