SQL - requête sur les 15 derniers jours

Résolu/Fermé
Signaler
Messages postés
38
Date d'inscription
mercredi 4 février 2009
Statut
Membre
Dernière intervention
7 mai 2009
-
Messages postés
38
Date d'inscription
mercredi 4 février 2009
Statut
Membre
Dernière intervention
7 mai 2009
-
Bonjour,

J'utilise une BD SQL.

J'aimerai retourner les résultats d'une requête pour les 15 derniers jours :

Je précise :
j'ai un champ "date" au format suivant : jj/mm/aaaa hh:mm:ss
Le résultat important est la moyenne du champ "attribute" par jour.

ce que je faisais jusqu'alors :

SELECT DATEPART(year, date), DATEPART(month, date), DATEPART(day, date), itemName, AVG(attribute)
FROM ma_table
WHERE (attribute LIKE 'xxx%')
AND (MONTH(itemDate) = MONTH(GETDATE()))
AND (YEAR(itemDate) = YEAR(GETDATE()))
AND (DAY(itemDate) BETWEEN DAY(GETDATE() - 15) AND DAY(GETDATE()))
AND (itemName = 'x.x.x.x')
GROUP BY itemName, DATEPART(year, date), DATEPART(month, date), DATEPART(day, date)


Sauf que : si nous sommes le 6 du mois, à cause du MONTH(GETDATE()), sql ne me retournera aucun résultat.
Or je voudrais afficher les résultats pour les 6 derniers jours du mois n et les 9 précédents du mois n-1 (donc des 15 derniers jours).

La tête dans le guidon, je sèche. Je n'ai plus d'idée pour tenter de remédier à ce problème!
J'espère que vous pourrez m'aider, par avance merci.

Furasque

4 réponses

Messages postés
1263
Date d'inscription
mercredi 26 septembre 2007
Statut
Membre
Dernière intervention
29 juillet 2010
1 369
Bonjour Furasque,

Je pense que ton ordre sql devrait être le suivant:
SELECT DATEPART(year, date), DATEPART(month, date), DATEPART(day, date), itemName, AVG(attribute)
FROM ma_table
WHERE (attribute LIKE 'xxx%')
AND itemDate between GETDATE() - 15 and GETDATE()
AND (itemName = 'x.x.x.x')
GROUP BY itemName, DATEPART(year, date), DATEPART(month, date), DATEPART(day, date)


A plus
1
Merci

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

CCM 41989 internautes nous ont dit merci ce mois-ci

Messages postés
2138
Date d'inscription
jeudi 29 janvier 2009
Statut
Membre
Dernière intervention
7 mars 2013
511
Bonjour,

Peut-être pouvez-vous utiliser ceci en adaptant de peu

SELECT SUBDATE('1998-01-02', INTERVAL 31 DAY);
Messages postés
38
Date d'inscription
mercredi 4 février 2009
Statut
Membre
Dernière intervention
7 mai 2009
1
Merci de votre réponse!
Cependant ça n'a pas l'air de fonctionner sous SQL server
Messages postés
38
Date d'inscription
mercredi 4 février 2009
Statut
Membre
Dernière intervention
7 mai 2009
1
Christounet,
je pensais que le format de ma date empêcherait cela mais non!
Ca fonctionne, merci bcp!