Sinon, j’utilise des entier, mais je trouvais plus clair ds l’exemple d’utiliser des lettres que des chiffre
edit: désolé d’être stupide, mais est-ce que vous pouvez me donner l’url du manuel de mysql où on parle de l’utilisation de IN. Pcq impossible de trouver (c’est super de chercher “in” dans un texte :p)… merci d’avance
edit2: est-ce plus gourmand en ressource de faire pls requete en mysql et d’avoir directement ce que j’ai besoin ou de n’en faire qu’une seule et de traiter les informations en php?
ça depend de la config mais a chaque requete sql il y a des echange reseau (sauf si local) des ouverture de session , du parsing , des gestion de cache etc …
donc vaut mieu une seul requete et faire du php derriere…
c’est dans la doc, certainement dans la partie “opérateur de comparaison”
édition :
[i]expr IN (value,…)
Returns 1 if expr is any of the values in the IN list, else returns 0. If all values are constants, then all values are evaluated according to the type of expr and sorted. The search for the item is then done using a binary search. This means IN is very quick if the IN value list consists entirely of constants. If expr is a case-sensitive string expression, the string comparison is performed in case-sensitive fashion:
mysql> SELECT 2 IN (0,3,5,‘wefwf’);
-> 0
mysql> SELECT ‘wefwf’ IN (0,3,5,‘wefwf’);
-> 1
The number of values in the IN list is only limited by the max_allowed_packet value. From 4.1 (to comply with the SQL-99 standard), IN returns NULL not only if the expression on the left hand side is NULL, but also if no match is found in the list and one of the expressions in the list is NULL. From MySQL version 4.1, an IN() clause may also contain a subquery. See section 13.1.8.3 Subqueries with ANY, IN, and SOME.
expr NOT IN (value,…)
Same as NOT (expr IN (value,…)). [/i]
merci infiniement! finallement j’ai pas utilisé de IN, en réalité, j’ai meme essayé de l’utiliser sans arriver à en trouver l’interet dans mon cas, je me suis donc replié sur une simple jointure
du type
SELECT * FROM table1, table2 WHERE table1.`id`=table2.`nom`
puis je stocke toutes les données dans un tableau à deux dimensions du type $tableau[cat][id] = titre que je parcours après avec la requete suivante
mais maintenant se pose un autre problème et pas des moindres (je vous harcele légèrement avec mes histoires, mais vous y répondez tellement gentillement que je ne peux m’empecher de continuer):
Pour chaque titre, j’ai une table annexe où sont stocké des commentaires. Mon but est d’indiquer à coter de chaque titre, dans ma liste, le nb de commentaire lié à ce dernier.
Le problème est évident: je me retrouve à faire une requete par titre
ayant ma requete générale:
while(SELECT * FROM table1, table2 WHERE table1.`id`=table2.`nom`)
{
// il me faudrait ici meme, stocker dans un autre tableau, le nb de commentaire, et cela pour chaque titre
$tableau[Cat][id] = titre;
}
je suis donc obligé de faire une requete par boucle, et vu qu ma page est susceptible de contenir à terme des centaines de titre, je vais avoir une centaine de requete, uniquement pour avoir le nb de commentaires postés. Impenssable!
Deux solutions s’offre à moi:
oublier cette fonction qui somme toute n’est pas essentielle,
m’en remettre à vous…
Je commence par la seconde, et je me rabattrais sur la première si vraiment vous n’avez pas d’idées.
j’vais finir par m’acheter un bouquin sur mysql, ca me ferait pas de tort à force de bidouiller comme ca
edit: ce qui n’empeche que j’ai un problème, auquel vous pourrez sans doute m’aider. Je ne sais jamais où trouver l’info. Par exemple, la doc de mysql n’explique absolument pas à quoi sert exactement group by, ou join… Il n’explique que sa synthaxe. Dès lors, cmt je dois faire pour comprendre moi
merci de ton lien (je sais que c’est tjs les meme que tu donnes et redonne, mais bon, je pense pas tjs a aller voir mes classiques)…
tu as un livre à conseiller (sinon celui qui est conseillé sur le site)?
sinon, niveau ressource, tu dis que ma jointure est merdique. Je le concoi tout à fait mais en quoi l’utilisation de JOIN me la rend plus propre? (et pi je comprend pas trop cmt ca marche)… je continue à m’acharner, mais si tu as deux minutes pour m’expliquer…
edit: j’ai compris l’histoire du group by mais je comprend pas vraiment le LEFT JOIN…
Qu’on soit clair : j’avais fait le test, JOIN et le produit cartésien c’est normalement équivalent au niveau temps d’éxécution.
Sauf qu’avec JOIN (et INNER JOIN) tu mets tout ce qui concerne les jointures dans un seul côté, ce qui favorise la relecture de la requête. Ce qui n’est pas le cas de la tienne. D’autant que si tu veux ajouter des conditions au WHERE, tu dois faire un AND ( … ) et pour peu que tu te gourres, tu fais un OR ou alors, ton AND ne prend que la première opérande disponible et ça ramouille. Bref…
La syntaxe du JOIN est très simple :
SELECT *
FROM ta A, tb B
WHERE A.id = B.id
Donne :
SELECT *
FROM ta A
INNER JOIN tb B ON A.id = B.id
A noter qu’avec ça, tu peux faire des zolis LEFT JOIN, ou RIGHT JOIN selon le besoin. Par exemple, si tu veux récolter les sujets d’un forum, et récolter le nom de l’utilisateur, tu utiliseras typiquement un LEFT JOIN pour tout le temps prendre les sujets du forum même s’ils ne correspondent pas à un utilisateur.
en gros ce que veut dire sans-nom (sisi il a voulu dire quelque chose, enfin je crois)
c que un bete produit cartesien amene en resultat des lignes qui correspondent a des enregistrement present dans les DEUX table (donc une intersection en terme ensembliste)
alors qu avec un left join on ramene dans tous les cas tous les enregistrements de la table maitre et ceux de la table left joinée si il y en a