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

Langage PHP Discussion :

Erreur de syntaxe sur INSERT en MySql


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Homme Profil pro
    en retaite
    Inscrit en
    Mai 2010
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : en retaite
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 164
    Points : 99
    Points
    99
    Par défaut Erreur de syntaxe sur INSERT en MySql
    Bonjour à tous,

    Je ne comprends pas la raison du blocage de cette requête mysql :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $my_sql = " INSERT INTO mails_a_envoyer ( id_train_mail,      id_emetteur,      id_destinataire,     nom_groupe_destin,      mail_objet,      mail_contenu,      nb_pj,       dossier_pj,       date_heure_envoi,      date_heure_ouvert,      mail_statut   ) ";
    		$my_sql.= " VALUES                   ( '{$id_train_mail}', '{$id_emetteur}', '{$id_destinataire}', {$nom_groupe_destin}', '{$mail_objet}', '{$mail_contenu}', '{$nb_pj}',  '{$dossier_pj}',  '{$date_heure_envoi}',    null ,               '{$mail_statut}' ) ";  
    		//echo " <br> TXT en 276 : ".$my_sql; echo "<br>"; echo "<br>"; echo "<br>"; echo "<br>"; 
    		$result_3 = mysqli_query($my_cnx, $my_sql) or die ('Erreur en 276 : '.mysqli_error($my_cnx) );
    J'ai (presque) tout essayé comme 'encadrement' de mes variables avant de les proposer à cette requête et je reçois toujours le même message d'erreur :

    " Erreur en 276 : Erreur de syntaxe près de 'adressé aux Membres du BUREAU ', 'aaaaaaaaaaaaaaa', ' "
    Comment identifier la variable (ou le champ) où se trouve l'erreur ?

    Y a-t-il un 'encadrement' qui ferait fasse à toutes les natures et contenus des variables ?

    Merci de votre aide.

    Cordialement
    Maub

    PS - je développe sous WAMP windows 10 avec php 8

  2. #2
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 59
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 628
    Points
    3 628
    Billets dans le blog
    8
    Par défaut
    Bonjour.
    1) Contrairement à ce que suggère le nom de ta variable, tu n'es pas en mysql, mais dans un autre SGBD : mysqli.
    Donc, pour ta compréhension, je te conseille de renommer ta variable $sql.

    2) Tu dois tester une insertion à la main dans ton phpmyadmin, récupérer le code SQL, puis le copier, c'est plus sûr. ex : tu détecteras peut-être que le champ où tu insères null n'est pas "nullable".

    3) Ensuite, sur cette base solide, il te faut faire une requête préparée, pour régler tous les problèmes d'échappement. Le code type est dans l'exemple 1 du saint manuel PHP.

    https://www.php.net/manual/fr/mysqli.prepare.php

  3. #3
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 420
    Points : 15 789
    Points
    15 789
    Par défaut
    quand une requete ne fonctionne pas, affichez là en entier et testez là dans phpmyadmin.

    et pour construire une requete, il vaut mieux utiliser une requete préparée plutot que de concaténer des chaines de caractères :
    https://www.php.net/manual/fr/pdo.pr...statements.php

  4. #4
    Membre régulier
    Homme Profil pro
    en retaite
    Inscrit en
    Mai 2010
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : en retaite
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2010
    Messages : 164
    Points : 99
    Points
    99
    Par défaut Bravo et Merci
    Je vous remercie pour votre aide et les différents conseils reçus.
    Ma difficulté est résolue !

    Bien cordialement
    Maub85

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

Discussions similaires

  1. Problème avec INSERT dans MySQL
    Par Ercan67000 dans le forum Débuter
    Réponses: 4
    Dernier message: 09/01/2012, 09h17
  2. [Mysql 3.23.58] Problème avec insert
    Par trihanhcie dans le forum Requêtes
    Réponses: 2
    Dernier message: 11/08/2006, 11h04
  3. Réponses: 3
    Dernier message: 10/05/2005, 11h02
  4. Problème d'insertion ( équivalence mysql )
    Par syl2095 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 03/12/2004, 17h35
  5. STL : std::set problème avec insert ...
    Par Big K. dans le forum MFC
    Réponses: 13
    Dernier message: 08/11/2003, 01h02

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