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 :

Erreur de requête [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2012
    Messages
    112
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2012
    Messages : 112
    Par défaut Erreur de requête
    Bonjour,
    je suis entrain de développer un site web dynamique, mon requête sql s'exécute sans problème sous easyphp mais j'ai une problème lorsque j'utilise cette requête sous php.
    Le code est le suivant :
    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
    23
    24
    25
    26
    <?php
    include("conexion_bd.php");
    	 if(isset($_POST["Valider"]) && $_POST["Valider"])
    	 {
    	$Titre = $_POST['Titre'];
    	$Auteur = $_POST['Auteur'];  
    	$Date = $_POST['Date'];
    	$Classification = $_POST['Classification'];  
    	$Résumé = $_POST['Résumé']; 
    	$Article = $_POST['Article'];
    	$req="insert into article (Titre,Auteur,Date,Classification,Résumé,Article) values ('".$Titre."', '".$Auteur."', '".$Date."', '".$Classification."', '".$Résumé."' ,'".$Article."')";
     
    $resultat=mysql_query($req,$connection);
    if($resultat){
    echo "<h1><font color=\"#000066\"> Félicitation</font><br />";
    ?>
    <body>
    .... 
    ....
    ....
    </body>
     
    <?php
    }
    else{ 
    echo "erreur insertion  ".$req;?>

    Le message d'erreur est qu' il y a une erreur d'insertion
    erreur insertion insert into article (Titre,Auteur,Date,Classification,Résumé,Article) values ('Titre', 'Auteur', '12/01/2012', 'Classification', 'Résumé' ,'Article')

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    	$Résumé = $_POST['Résumé'];
    1/ Tu devrais éviter absolument d'écrire des variables avec des accents.
    Idem pour les champs en base de données.
    En PHP, les variables sont représentées par un signe dollar "$" suivi du nom de la variable. Le nom est sensible à la casse.

    Les noms de variables suivent les mêmes règles de nommage que les autres entités PHP.

    Un nom de variable valide doit commencer par une lettre ou un souligné (_), suivi de lettres, chiffres ou soulignés. Exprimé sous la forme d'une expression régulière, cela donne : '[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*'
    2/ Afficher les erreurs SQL :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $req="...";
    $resultat=mysql_query($req,$connection) or die('Erreur SQL :<br />'.$req.'<br />'.mysql_error()); // en développement (TEST LOCAL)
    // $resultat=mysql_query($req,$connection); // en production
    3/ Attention aux injections SQL !
    On ne mets JAMAIS de $_POST directement dans une requête SQL, sans avoir vérifié les données !

    Avec mysql_, il suffit de mettre mysql_real_escape_string() :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $Titre = mysql_real_escape_string($_POST['Titre']);
    //...

    4/ mysql_ est obsolète.
    Il faut utiliser MySQLi ou PDO_MySQL.
    Dernière modification par Invité ; 13/09/2013 à 10h43.

  3. #3
    Membre confirmé
    Homme Profil pro
    Webmaster
    Inscrit en
    Janvier 2006
    Messages
    132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Webmaster
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2006
    Messages : 132
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $req = "INSERT INTO article (Titre, Auteur, Date, Classification, Résumé, Article) values ('$Titre', '$Auteur', '$Date', '$Classification', '$Résumé' ,'$Article')";
    .

    En plus d'éviter les accents, il faut éviter les majuscules en début de mot (c'est pas obligatoire mais les programmeurs l'adopte.

    Les mots clé PHP en majuscule.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par moudjahidine Voir le message
    il faut éviter les majuscules en début de mot
    En fait, c'est un choix à faire. Plusieurs conventions existent : "CamelCase"
    • en UpperCamelCase, la première lettre est en majuscules,
    • en lowerCamelCase, elle est en minuscule.

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2012
    Messages
    112
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2012
    Messages : 112
    Par défaut
    Merci beaucoup mes amis

  6. #6
    Invité
    Invité(e)
    Par défaut
    Attention aussi aux "mots réservés SQL" :

    Date est un mot réservé en SQL.
    A éviter aussi.

    Si vraiment tu veut l'utiliser comme nom de champ, il faut alors écrire :

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

Discussions similaires

  1. [MySQL] Erreur de requête
    Par Sebe dans le forum PHP & Base de données
    Réponses: 45
    Dernier message: 08/02/2006, 14h09
  2. [PHP MySQL] Erreur execution requête de type INSERT
    Par Pfeffer dans le forum Requêtes
    Réponses: 6
    Dernier message: 23/01/2006, 17h38
  3. [Debutant]Erreur Récurent - Requête
    Par ghan77 dans le forum Bases de données
    Réponses: 19
    Dernier message: 10/01/2006, 13h09
  4. erreur exécution requête
    Par MANU_2 dans le forum Bases de données
    Réponses: 4
    Dernier message: 13/10/2005, 07h27
  5. Erreur de requête :-(
    Par pekka77 dans le forum ASP
    Réponses: 2
    Dernier message: 28/06/2005, 13h53

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