Problème requête sql

tidus -  
papillonetta Messages postés 33 Statut Membre -
Bonjour,

Voici ma requête:

select *
from stock
where villestock="nimes"
or villestock="montpellier"
and qtédispo<=20
and Pu>1000;

Et voici la correction du prof (il a rajouté des parenthèses)

select *
from stock
where (villestock="nimes"
or villestock="montpellier")
and qtédispo<=20
and Pu>1000;

Mon problème tout simple pourquoi a-t-il mis des parenthèses?

Merci

4 réponses

jee pee Messages postés 42661 Date d'inscription   Statut Modérateur Dernière intervention   9 790
 
bonjour,

quand une requête est traitée, l'ordre dans lequel les opérateurs sont pris en compte est important.

si tu exprimes ta condition dans une phrase, toi et moi comprenons bien que il faut chercher une pièce en stock dans l'une des 2 villes

le moteur sql lui réagit différemment, il traite le AND avant le OR donc :
il prend les lignes de la table avec :

- villestock="montpellier" and qtédispo<=20
- puis parmi celles ci celles and Pu>1000;

et puis il va traiter la condition or villestock="nimes" toute seule, donc il rajoute toutes les lignes de nimes, sans prendre en compte les critères qtédispo et pu

alors qu'en utilisant les parenthèses, tu lui dit de commencer par traiter
(villestock="nimes" or villestock="montpellier")

puis sur cette première sélection, il va appliquer les autres restrictions

Donc il faut utiliser les parenthèses pour préciser explicitement l'ordre de prise en compte des opérateurs

cdt
2
gams87 Messages postés 200 Date d'inscription   Statut Membre Dernière intervention   72
 
je pense tt simplement que c'est parceque ca fait partie de la meme ligne enfin les deux termes entre parenthèse vont ensemble
si tu av mis AND machin...... la il aurait pas fallu de parenthèse
je sais pas si g été très clair la ;-(
1
sovi Messages postés 19 Statut Membre 1
 
En plus de ce que dit jee pee et gams87 (que j’approuve d'ailleurs ), je te propose de voir les choses comme suit.
On peut penser simplement qu’il s’agit de trouver des objets en stocks dans 2 villes différentes.
Et la requête doit d’abord nous dire de quel stock sagit –il ? (En réalité dans quelle ville de stockage, on veut trouver l’objet ?). Ensuite, il doit préciser la quantité disponible et le prix unitaire de l’objet en stock). Tu conviens donc avec moi que dans cette démarche, le choix de la ville de stockage (villestock="nimes" or villestock="montpellier) constitue en lui-seul un critère « entier » de sélection (à respecter avant tout).

C’est pour cela que gams87 disait « les deux termes entre parenthèse vont ensemble ».
D’aucun dirait qu’il faut bien savoir où sélectionner avant de savoir ce qu’on sélection, sa quantité ou autre propriété (le prix unitaire par exemple) le concernant.

J’espère avoir apporté un plus pour t’aider à comprendre.
Si tu as compris, laisse un mot (ça tranquillise !)
0
papillonetta Messages postés 33 Statut Membre
 
les parenthéses consistent a regrouper les instructions ensemble
parsque ca risque de regrouper l"or" avec le "end"
0