[PHP/MYSQL] Problème de requête avec "LIKE" [Résolu/Fermé]

flagoustou - 22 mars 2012 à 11:18 - Dernière réponse : maka54 699 Messages postés mercredi 8 avril 2009Date d'inscription 4 décembre 2016 Dernière intervention
- 22 mars 2012 à 14:22
Bonjour,
J'ai un petit soucis avec une requête SQL,
J'ai un champ qui comporte comme valeur (3;1;)

Pour trier tout ça, je lance comme requête :
SELECT * FROM 'offre' WHERE idcategorie LIKE '3;'


Mais malheureusement (et c'est le comportement normal du LIKE) il me retourne des valeurs comme "13;" "23;".

Comment puis faire pour que j'ai un retour seulement avec les "3;" ?
(Le soucis étant que mes valeurs de champs ne sont jamais unique =>"3;1;" =>"1;13;14;"...)
Afficher la suite 

8 réponses

bissdebrazza 2072 Messages postés vendredi 29 juin 2007Date d'inscriptionContributeurStatut 7 décembre 2017 Dernière intervention - 22 mars 2012 à 11:49
+1
Utile
donc tu veux que tes valeurs ne s'affichent que "3;" ? si c'est le cas, pourquoi ne pas mettre une égalité?
Cette réponse vous a-t-elle aidé ?  
bissdebrazza 2072 Messages postés vendredi 29 juin 2007Date d'inscriptionContributeurStatut 7 décembre 2017 Dernière intervention - 22 mars 2012 à 11:34
0
Utile
1
Salut!
essai ça:
SELECT * FROM 'offre' WHERE idcategorie LIKE '3;%'

Pas trop bien compris,donc dis moi si c'est ce que tu veux!
Merci pour ta réponse rapide !

En faite je veux récupérer les champs qui ont uniquement une valeur de "3;" (par exemple).

Malheureusement avec LIKE '3;%' ou LIKE '%3;%' ou LIKE %3;' ça ne fonctionne pas, car le résultat de SQL me donne comme réponse : "13;" "23;" "3;".

Et j'aimerai récupéré les champs qui ont comme valeur "3;".

(les "LIKE '3;%" ne fonctionnent pas car j'ai certaines valeurs comme "11;3;").
flagoustou - 22 mars 2012 à 11:51
0
Utile
l'égalité ne fonctionne pas car mes champs ne sont jamais égales à "3;" uniquement, il y a d'autre valeur avec comme "11;3;" au sein du même champs par exemple.

D'où l'utilisation du "LIKE "et non de "=".
Mopra-L 146 Messages postés lundi 29 juin 2009Date d'inscription 23 mai 2012 Dernière intervention - 22 mars 2012 à 12:21
0
Utile
Pour le coup, je ne sais pas si c'est possible, car il faudrait s'assurer que le caractère avant le 3 soit vide, ou égal à ";"


Une solution "bidouille" serait de rajouter un ";" devant chaque ligne, et du coup, de rechercher sur la valeur ";3;" ensuite.

flagoustou - 22 mars 2012 à 12:24
0
Utile
Excellent ! je n'y avais pas pensé!
Merci pour ta réponse.

Je vais faire mes modifications en début d'après midi et je te tiens au courant !
flagoustou - 22 mars 2012 à 13:30
0
Utile
Merci beaucoup !
Voilà problème résolu !
maka54 699 Messages postés mercredi 8 avril 2009Date d'inscription 4 décembre 2016 Dernière intervention - 22 mars 2012 à 14:22
0
Utile
Il y a un problème de conception

une offre pouvant avoir plusieurs catégorie (à moins que je me trompe)

tu devrais avoir une table supplémentaire qui fasse le lien entre offre et catégorie

offre
------
id_offre
contenu_offre


categorie
----------
id_categorie
libelle_categorie


offre_categorie
--------------
id_offre
id_categorie