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 :

[SQL] problème de requête


Sujet :

PHP & Base de données

  1. #1
    Nouveau candidat au Club
    Inscrit en
    Février 2007
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 1
    Par défaut [SQL] problème de requête
    Bonjour à tous

    Je tiens à préciser que je débute en php et que je ne suis pas très fort en SQL !

    Voici mon problème : je suis en train de coder un livre d'or pour mon site mais j'ai un problème depuis que j'ai ajouter la psosibilité de mettre une note avec le message

    La requête INSERT INTO n'a pas l'air de fonctionner. La voici :

    mysql_query('INSERT INTO livre (pseudo, message, note) VALUES ('.$pseudo.','.$message.','.$note.')') or die (mysql_error());


    je récupère les données dans les variables de la facon suivante :

    $message = htmlentities ($_POST['message'], ENT_QUOTES);
    $message = nl2br($message);
    $pseudo = htmlentities ($_POST['pseudo'], ENT_QUOTES);
    $note = $_POST['note'];


    Quelqu'un aurait-il une idée? ca fait 1h que je me casse la tête sans comprendre l'erreur

    Merci d'avance a toute aide

    Sh4dow

  2. #2
    Membre Expert
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juillet 2004
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 725
    Par défaut
    Normal:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    mysql_query('INSERT INTO livre (pseudo, message, note) VALUES ("'.$pseudo.'", "'.$message.'", "'.$note.'")') or die (mysql_error());
    Essaye ca

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Pour compléter la suggestion de cerede2000 (avec affichage de la requête en plus du message d'erreur)
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $rq ='INSERT INTO livre (pseudo, message, note) VALUES ("'.$pseudo.'", "'.$message.'", "'.$note.'")';
    $res = mysql_query($rq) or die ("requete : $rq : ".mysql_error());
    Bon courage !
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  4. #4
    Membre confirmé
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    66
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 66
    Par défaut
    Salut,

    Je me join à votre conversation car je ne comprend pas vos reponses.

    Citation Envoyé par Celira
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $rq ='INSERT INTO livre (pseudo, message, note) VALUES ("'.$pseudo.'", "'.$message.'", "'.$note.'")';
    $res = mysql_query($rq) or die ("requete : $rq : ".mysql_error());
    moi au lieu de mettre des guillemets j'aurais enlever les points.
    j'aurais plutot mis ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $rq ='INSERT INTO livre (pseudo, message, note) VALUES ('$pseudo', '$message', '$note')';
    Pouvez vous m'expliquer la différence.

  5. #5
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Février 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2007
    Messages : 97
    Par défaut
    Citation Envoyé par benoît82
    Salut,

    Je me join à votre conversation car je ne comprend pas vos reponses.



    moi au lieu de mettre des guillemets j'aurais enlever les points.
    j'aurais plutot mis ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $rq ='INSERT INTO livre (pseudo, message, note) VALUES ('$pseudo', '$message', '$note')';
    Pouvez vous m'expliquer la différence.
    La différence réside dans les quotes...
    Ici tu as mis
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $rq = 'INSER INTO ......Values ('$pseudo'....)
    Or si tu laisses de cette manière tu vas avoir un problème car la quote tu mets devant $pseudo va être interprété comme étant la fermeture de la quote du début de la requête.

    Tu peux cependant faire comme tu l'as dit en mettant un guillemet
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $rq = "INSER INTO ......Values ('$pseudo'....)"
    j'espere que j'ai été clair

  6. #6
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Benoit82, c'est une question de syntaxe et de concaténation :

    Dans la requête, il faut mettre les valeurs à insérer entre quotes. Et comme on utilise les simples quotes (') pour encadrer la requête, le plus simple est d'utiliser des doubles quotes (") pour les valeurs.

    Les points, c'est pour la concaténation et le traitement des variables. Dans une chaine encadrée par des ", les variables sont traduites, pas dans une chaine encédrée par des '.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    $a = "celira";
     
    echo " nom : $a";
    // nom : celira
     
    echo ' nom : $a';
    // nom : $a 
     
    echo ' nom : '.$a;
    // nom : celira
     
    echo " nom : '$a' ";
    // nom : 'celira'
     
    echo ' nom : "$as" '
    // nom "$a"
     
    echo ' nom : " '.$a.' " ';
    // nom : " celira "
     
    echo 'nom : ' $a ' ';
    // ERREUR !!!!!!
    j'espère avoir été claire
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  7. #7
    Membre confirmé
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    66
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 66
    Par défaut
    Ok je vous remerci pour vos explication

    J'ai compris la différence que j'avais dans mes requetes.

    Je n'avais pas vu que dans le code la requete etait entre quote alors que moi j'ai l'habitude de le mettre entre guillemet comme dans le dernier code de musicann.

    merci à vous deux.

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

Discussions similaires

  1. [SQL] Problème de requête et <tr>+<td>
    Par ruty dans le forum PHP & Base de données
    Réponses: 16
    Dernier message: 15/08/2006, 09h10
  2. [SQL] Problème bizarre requête date
    Par masseur dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 17/02/2006, 13h12
  3. [Oracle] [SQL] problème de requête
    Par joselito dans le forum PHP & Base de données
    Réponses: 24
    Dernier message: 25/01/2006, 12h55
  4. [SQL]problème de requête.
    Par shnouf dans le forum Oracle
    Réponses: 21
    Dernier message: 24/01/2006, 11h12
  5. [SQL] Problème de requête SQL de plus de 8060 caractères ?
    Par webtheque dans le forum MS SQL Server
    Réponses: 13
    Dernier message: 06/04/2005, 15h07

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