Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD
PHP & SGBD Forum d'entraide sur les SGBD avec PHP. Avant de poster : FAQ BDD, toutes les FAQ PHP, cours BDD et sources BDD
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 12/02/2007, 15h33   #1
Inscrit
 
Inscription : juin 2006
Messages : 531
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 531
Points : 225
Points : 225
Par défaut [SQL] Ma requête renvoie tous les tuples et ne respecte pas la condition AND

Bonjour,

La requête suivante est censée retourner tous les tuples dont le pays est identifié par la valeur 4 dans le champ pays de la table pageProGratuite :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
SELECT 
idMembre,
ville,
nom
FROM pageProGratuite 
WHERE 
specialiteA='".$specialite."'
OR
specialiteB='".$specialite."'
OR
specialiteC='".$specialite."'
OR
specialiteD='".$specialite."'
OR
specialiteE='".$specialite."'
AND pays=4
AND fermer=0
ORDER BY codePostal
Mais ça me retourne tous les tuples, quelle que soit la valeur dans le champ 'pays'.

Ca doit être un problème au niveau des OR ou AND etc...


Merci d'avance pour votre aide.
JackBeauregard est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/02/2007, 15h40   #2
Expert Confirmé

 
Avatar de Amara
 
Inscription : juillet 2004
Messages : 2 684
Détails du profil
Informations personnelles :
Localisation : France, Sarthe (Pays de la Loire)

Informations forums :
Inscription : juillet 2004
Messages : 2 684
Points : 2 910
Points : 2 910
Pas de rapport avec PHP donc c'est pas le bon forum mais à mon avis c'est un souci de priorité (exactement comme les + et les * dans les opérations), le AND pays=4 ne s'appliquant en fait que pour la spécialité5, il faut parenthéser tout ça au propre et ça ira peut-être mieux.
__________________
Pas de questions techniques par MP, le forum est là pour ça et est plus efficace.

Orthographe : une connexion (avec un x), un langage (sans u), une requête (un seul t), 'une quote' (avec qu), une syntaxe (sans h)
Amara est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/02/2007, 15h43   #3
Membre confirmé
 
Avatar de mussara
 
Inscription : novembre 2004
Messages : 441
Détails du profil
Informations personnelles :
Âge : 44

Informations forums :
Inscription : novembre 2004
Messages : 441
Points : 299
Points : 299
enleve de ta requete les lignes sur les spécialités

pour n'avoir plus que la requete suivante:

Code sql :
1
2
3
4
5
SELECT idMembre,ville,nomFROM pageProGratuite 
WHERE 
pays=4
AND fermer=0
ORDER BY codePostal

si la requete ne te sors que des tuples sur le pays 4 alors il faudra que tu mettes entre parenthèses la partie ou il y a les "OR"
mussara est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/02/2007, 13h33   #4
Inscrit
 
Inscription : juin 2006
Messages : 531
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 531
Points : 225
Points : 225
Bon c'est résolu, merci à vous tous

C'ets vrai que c'était simple
JackBeauregard 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 02h08.


 
 
 
 
Partenaires

Hébergement Web