-
Sélection avec IN
Bonjour,
Ma base de données MySql est alimentée par diverses sources dont je n'ai pas forcement le contrôle. Résultat des courses, pour certaines informations qui s'y trouvent, j'ai des caractères invisibles (ou spéciaux - j'ai du mal à les identifier) qui viennent fausser mes résultats de requête.
Je vous explique : je fais un SELECT sur une liste d'emails (via un IN).
ex : SELECT * FROM inscrit WHERE email IN ('email1@test.fr','email2@test.fr','email3@test.fr','email4@test.fr')
Ma requête va par exemple me sortir les résultat pour email1, email2 et email3, mais rien pour email4@test.fr
Pour vérifier je fais un SELECT sur email='email4@test.fr' et en effet je n'ai rien. Par contre si je fais email LIKE '%email4@test.fr%', là j'ai des résultats.
Dans mon PHPMyAdmin, la valeur apparaît bien sous email4@test.fr. J'ai donc l'impression qu'il y a des caractères spéciaux invisibles qui l'entourent.
Le problème est que je suis obligé de passer par un IN car je dois pouvoir traiter un grand nombre d'emails.
J'aimerais donc savoir de quelle alternative je dispose (l'idéal serait un mix entre IN et LIKE). Auriez-vous une solution à me proposer.
Pour info ma donnée email est un varchar(255)
Merci d'avance
-
Salut
Dans un premier temps je passerais les fonctions ltrim et rtrim sur ton champs email
LTRIM(str) permet de faire sauter les espaces initiaux
RTRIM(str) permet de faire sauter les espaces finaux
D'ailleurs pour savoir si c'est bien les espaces qui te posent problème, recherche
select * from table
where email like ' email4@... ' ( j'ai rajouter des espaces pour voir si c'est ca !!!)
Sinon j'ai pa trop d'idées!!!
Bonne chance
-
Si vous souhaitez supprimer tous les espaces initiaux et finaux, sous MySQL la fonction TRIM existe.
Pour corriger le problème à court terme, exécutez la requête :
Code:
UPDATE TABLE SET EMAIL=TRIM(EMAIL)
Pour corriger le problème à moyen terme, revoyez votre script qui va lancer l'insertion de données. Vérifiez que les données sont correctement formatées et donc qu'un trim($mail) (exemple php) est bien executé avant l'insertion.
Pour corriger le problème sur du plus long terme, pour tous vos développement, avant chaque interraction avec votre base, vérifiez toujours les données (absence de séparateurs type ' " , absence d'espace superflus)
-
Merci pour vos réponses, je vais tester toutes ces pistes.
-
J'ai identifié les caractères superflues. Il s'agit de \r\n.
Du coup j'ai réadapté ma requête comme ceci :
SELECT * FROM inscrit WHERE REPLACE(email,'\r\n','') IN ('email1@test.fr','email2@test.fr','email3@test.fr','email4@test.fr')
Il semblerait que cela fonctionne.
Que pensez-vous de cette solution ?
-
Elle est moins bonne que les TRIM. Trim virent les espaces superflus (y compris les retour chariot et retour lignes)
-
Je suis également convaincu que TRIM est une solution plus logique, mais malheureusement, il s'avère qu'elle ne corrige le problème de ma requête ... email4@test.fr n'est pas trouvé (comme au départ)
-
Bon, au final, j'ai nettoyé toute ma base en faisant un update sur les infos email.
Le TRIM ne m'apportant pas les résultats escomptés, j'ai fait un REPLACE(email,'\r\n','')
Merci à tous pour votre aide.