IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Problème pour comparer des valeurs avec accent [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut Problème pour comparer des valeurs avec accent
    Bonjour,
    Je ne comprends pas un truc.

    J'ai un formulaire qui ajoute des clients dans une base de donnée.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    	$sql_client = "SELECT id_clients,fd_name, fd_firstname FROM tb_clients WHERE id_clients LIKE ".$_POST['id_client']." OR (fd_name LIKE '".htmlentities($_POST['name'])."' AND fd_firstname LIKE '".htmlentities($_POST['firstname'])."')";
    	$query_client = mysql_query($sql_client)or die(mysql_error());
    	echo $nb_client = mysql_num_rows($query_client);
    On voir ci-dessous qui si les client existent déjà en fonction du nom et prénom, $nb_client retourne 1, et donc ensuite, il n'y aura pas d'insertion, mais un message d'erreur.

    Le problème c'est que ça marche avec les valeurs sans accent, mais pour ceux qui en ont eux, $nb_client retourne 0 alors qu'il devrait retourner 1.

    Je crois savoir pourquoi.
    Si je rentre José dans le champs prénom, par exemple cette valeur sera comparé avec José dans la base de donnée.

    Alors j'ai ajouté
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    htmlentities($_POST['firstname'])
    qui devrait changer la valeur José en José dans mon
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $_POST['firstname']

    Simplement ça ne marche toujours pas. $nb_client retourne toujours 0 alors qu'il devrait retourner 1, puisqu'il existe.
    J'aimerais juste encore préciser que dans mon exemple ci-dessus, considérons que le nom est également identique, dans le formulaire que dans la base de donnée.

    Une simple idée?
    Merci

  2. #2
    Membre émérite Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Points : 2 566
    Points
    2 566
    Par défaut
    Bonjour,

    tu peux faire un

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SHOW CREATE TABLE taTable;

    et voir si tu es bien en case insensitive (_ci) à la fin de ton CHARSET

  3. #3
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut
    Ben je ne vois pas trop comment.

    Dans ma base de donnée, si je regarde sous Oération, je vois sous Collation : latin1_swedish_ci et aussi bien sous la table tb_clients

  4. #4
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 098
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 098
    Points : 946
    Points
    946
    Par défaut
    J'ai résolu mon problème en remplaçant ceci
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    htmlentities($_POST['firstname'])
    par ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    htmlentities($_POST['firstname'],ENT_COMPAT,'UTF-8')
    Bonnes fêtes à tous!!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Toutes versions] problème pour regrouper des valeurs de cellules tout en respectant l'ordre
    Par songs_of_liberty dans le forum Excel
    Réponses: 5
    Dernier message: 16/04/2009, 18h43
  2. Problème pour insérer des enregistrements avec un Pilote ODBC
    Par Michel Giustina dans le forum AS/400
    Réponses: 2
    Dernier message: 21/03/2009, 19h18
  3. Réponses: 1
    Dernier message: 25/01/2009, 19h08
  4. Réponses: 6
    Dernier message: 28/12/2007, 22h34
  5. Problème pour forcer des valeurs d'un tableau
    Par n][co dans le forum Autres éditeurs
    Réponses: 3
    Dernier message: 25/04/2007, 20h59

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo