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 de quote dans une requete sql [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut Problème de quote dans une requete sql
    Bonjour,

    cela fait plusieurs jours que je suis sur ce problème que je n'arrive pas à comprendre et qui me parait pourtant anodin mais quand on a la tête dedans on voit plus la longueur d'une choppe.... confused


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $reponse = $bdd->query("SELECT * FROM `chien` WHERE nom = 'François Premier des Adrilines d\'Opale'");
     
    while ($donnees = $reponse->fetch())
    François Premier des Adrilines d\'Opale est biensur à la base dans une variable, je l'ai écrit complètement pour pouvoir tester mais même en dur, ça ne marche pas. Lorsque je met un nom sans quote cela fonctionne parfaitement. Il doit y avoir une " ou un ' qui m'échappe, un problème d'encodage ou autre, c'est pourquoi je viens ici réclamé un œil neuf.

    Lorsque je recopie directement la requête dans mysql, elle s'éxécute mais dans le code, je n'arrive pas à entrer dans ma boucle.

    J'espère que j'ai été assez explicite et que vous saurez m'aiguiller.

    Merci d'avance.
    Berew

  2. #2
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    Salut

    Je remarque ceci : François
    Il y a des majuscules/minuscules (la casse) et un ç, des caractères spéciaux.

    Alors peut être il y a t-il un problème à ce niveau.
    - Quel est l'encodage utilisé ? (du Latin, utf-8, etc ...)
    Es-tu certain que tout est correcte à ce niveau ? (fichiers, php, MySQL Bdd/tables/champs).

    - Pour la casse, le champ en tient il compte pas ?

  3. #3
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut
    Merci de m'accorder un peu de temps.

    Le nom "François Premier des Adrilines d\'Opale" est un copier coller de ma table donc pas de souci niveau casse, je peux même l'assurer puisqu'en copiant le contenu de la requête dans le sgbd, il n'y a pas de problème.

    Par contre je soupçonne fortement ton deuxième point d'être la cause de mes soucis. J'ai essayé de tout mettre en utf-8 mais apparemment je pense qu'il y a quelque chose qui ne va pas puisque lors d'une erreur, les caractères spéciaux de mysql sont transformé en symbole (ex: erreur pr�s de).

    Pour ma part, il me semblait pourtant avoir "tout" encodé en utf-8. Les fichiers j'en suis sur, la base et les tables également mais le reste je ne sais pas comment faire, tu pourrais m'aider?

  4. #4
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    Il me semble que c'est PDO que tu utilise. As tu rajouté quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8');
    Puis pour Php, as tu défini l'encodage pour l'entête : (pour toutes les pages)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    header('Content-Type: text/html; charset=utf-8');

    Un tuto, pour t'aider à faire le point (à part mysql_*) : Passez à l'UTF-8 sans manquer une étape

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut
    Pour php, pas de problème, c'est fait. J'utilise en effet pdo mais la ligne que tu as écrite ne me dit rien du tout.
    Merci pour le lien je vais regarder ça avec attention.

  6. #6
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut
    D'après mes tests, il ne s'agirait pas de l'échappement, j'ai fait un test conditionnel pour vérifier qu'un nom existe bien dans la base et à ma grande surprise je n'arrive pas à entrer dans mon if.


    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    if ($_GET['nom'] == htmlentities($donnees['nom']))


    Je soupçonne cet erreur d'être la même que celle qui m'a amené ici. N'y a-t-il pas un problème de transition de données entre mon fichier et la base? Je crois qu'on a cerné le problème, il ne "reste" plus qu'à le résoudre...

  7. #7
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    J'utilise en effet pdo mais la ligne que tu as écrite ne me dit rien du tout.
    C'est un code à rajouter lors de la connexion, sinon tu vas avoir (ou conserveras) un problème d'encodage.
    Poste ton code de cette partie là si nécessaire.


    if ($_GET['nom'] == htmlentities($donnees['nom']))
    Pourquoi utilise tu htmlentities() ?

    Il n'y a pas a utiliser htmlentities() surtout dans ce cas là, les 2 données ne données ne pourront jamais être égales à cause de ça, et c'est normal.

    Ceci devrait fonctionner :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if ($_GET['nom'] == $donnees['nom'])
    Si tu affiches les 2, qu'est ce que ça donne ?
    Quelle différence il y a lorsque les 2 sont égales, ou devraient l'être ?


    htmlentities() c'est fait pour afficher une données (brut) dans une partie HTML, ceci pour une question de sécurité, mais aussi pour éviter des conflits entre le contenu d'une données (les quotes simples ou double) placée dans un attribut HTML.
    De plus, il serait peut être plus simple d'utiliser htmlspecialchars() ça évite un problème d'encodage.


    Si htmlentities() est réellement nécessaire (que tout soit traduit en entités HTML), alors il faut renseigner les autres paramètres optionnels, entre autre l'encodage, car par défaut c'est de l'ISO.
    La doc : htmlentities()
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <p><?php echo htmlentities($donnee['nom'], ENT_QUOTES, 'UTF-8'); ?></p>

  8. #8
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut
    Si je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if ($_GET['nom'] == $donnees['nom'])

    ça me donne ça en valeur de retour

    get ----------------> François Premier des Adrilines d'Opale
    donnees -----------> Fran�ois Premier des Adrilines d'Opale

    c'est pour ça que j'utilise le htmlentities. J'ai trouvé un début de solution à mon problème mais j'ai besoin d'aide pour le résoudre. En fait ce n'est pas le quote la source de mon souci mais mon "ç" contenu dans François car en faisant :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    'SELECT * FROM `chien` WHERE `nom` LIKE "%Premier des Adrilines d\'Opale%"'
    La requête aboutit. Je me doutais bien que j'avais un problème d'encodage puisque lorsque j'ai une erreur, mysql me sort des symboles à la places des caractères spéciaux.

    Je te met ci-dessous mon fichier de connexion.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    try
    {
    	$pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    	$bdd = new PDO('mysql:host=localhost;dbname=clumber', 'root', '', $pdo_options);
    }
    catch (Exception $e)
    {
            die('Erreur : ça marche pas!!!' . $e->getMessage());
    }

  9. #9
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Avril 2012
    Messages : 23
    Points : 23
    Points
    23
    Par défaut
    Je me permet de refaire un message pour te dire merci pour tout !!
    J'ai résolu mon problème grâce à la petite ligne que tu avais mis au dessus

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8')

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

Discussions similaires

  1. Problème variable dans une requete SQL
    Par SimonAFDT dans le forum PL/SQL
    Réponses: 13
    Dernier message: 30/11/2009, 12h25
  2. Réponses: 2
    Dernier message: 27/05/2007, 13h26
  3. Probléme avec une varialbe dans une requete SQL
    Par wylls dans le forum Langage SQL
    Réponses: 25
    Dernier message: 18/12/2006, 15h45
  4. Quote dans une requete...
    Par Isildur dans le forum Langage SQL
    Réponses: 6
    Dernier message: 20/06/2006, 10h57
  5. Mettre a jour les Parametres dans une requete SQL
    Par Tartar Ukid dans le forum C++Builder
    Réponses: 7
    Dernier message: 31/03/2004, 13h51

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