Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 20/11/2007, 17h37   #1
Invité régulier
 
Développeur Web
Inscription : avril 2006
Messages : 12
Détails du profil
Informations personnelles :
Localisation : France, Somme (Picardie)

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : avril 2006
Messages : 12
Points : 5
Points : 5
Par défaut [MySQL 4.1.18] Erreur de syntaxe

Bonjour,

J'ai dans un script une requete qui récupère des enregistrements dans une table "reponses" selon un critère d'ancienneté :

Code :
1
2
3
SELECT COUNT(*) AS `nbr` 
FROM `reponses`
WHERE `rep_date` < SUBTIME('2007-11-18 00:00:00','21 00:00:00')
Cette première requete fonctionne bien et me retourne mon nombre d'enregistrements concernés.
Néanmoins, lorsque je remplace le "Count" par l'étoile "*" pour sélectionner tout le contenu de mes enregitrements à l'aide de la requête :

Code :
1
2
3
SELECT *
FROM `reponses`
WHERE `rep_date` < SUBTIME('2007-11-18 00:00:00','21 00:00:00')
... tout à coup ça ne fonctionne plus.
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '( '2007-11-18 00:00:00' , '21 00:00:00' )

J'avoue ne pas du tout comprendre pourquoi.

Version MySQL : 4.1.18.

Merci à vous,
Clem
ridefmx est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/11/2007, 08h47   #2
Membre éprouvé
 
Avatar de nounetmasque
 
Inscription : janvier 2003
Messages : 491
Détails du profil
Informations forums :
Inscription : janvier 2003
Messages : 491
Points : 488
Points : 488
Je ne pense pas que ce conseil résoudra ton problème mais plutôt que de tester la différence entre ton champ rep_date et le résultat de ta soustraction :
Code :
1
2
 
`rep_date` < SUBTIME('2007-11-18 00:00:00','21 00:00:00'
Je te conseille d'utiliser la fonction DATEDIFF.
__________________
"Dieu reste muet, si seulement nous pouvions convaincre l'être humain d'en faire autant."
nounetmasque est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 01h06.


 
 
 
 
Partenaires

Hébergement Web