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 :

apostrophe dans mysql [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Homme Profil pro
    Webdesigner
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Par défaut apostrophe dans mysql
    Bonjour,
    Voila j'ai un souci avec les apostrophes lorsque je veux faire un UPDATE avec php de ma base de données.
    Voici le code :
    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    <?php
    session_start();
    if (isset($_SESSION['id'])) {
       header('Location: ../index.php');
     
        exit;
    }
    $cnx = mysql_connect( "", "", "" ) ;
    $db = mysql_select_db( "" ) ;
     
      $login            = $_POST["login"] ;
      $nom_site            = $_POST["nom_site"] ;
      $url                = $_POST["url"] ;
      $banniere            = $_POST["banniere"] ;
      $backlink            = $_POST["backlink"] ;
       $rubrique        = $_POST["rubrique"] ;
       $mc1                = $_POST["mc1"] ;
       $mc2                = $_POST["mc2"] ;
       $mc3                = $_POST["mc3"] ;
       $mc4                = $_POST["mc4"] ;
       $mc5               = $_POST["mc5"] ;
       $mc6                = $_POST["mc6"] ;
       $mc7               = $_POST["mc7"] ;
       $mc8                = $_POST["mc8"] ;
       $mc9                = $_POST["mc9"] ;
       $mc10            = $_POST["mc10"] ;
       $email            = $_POST["email"] ;
       $descriptif        = $_POST["descriptif"] ;
      $id                = $_POST["id"] ;
      //création de la requête SQL:
    $sql ="mysql_real_escape_string() ";
    $sql = "UPDATE utilisateurs
                SET 
    login               = '$login', 
    nom_site            = '$nom_site',
    url                 = '$url',
    banniere            = '$banniere',
    backlink            = '$backlink',
    rubrique            = '$rubrique',
    mc1                = '$mc1',
    mc2                 = '$mc2',
    mc3                 = '$mc3',
    mc4                 = '$mc4',
    mc5                 = '$mc5',
    mc6                 = '$mc6',
    mc7                 = '$mc7',
    mc8                 = '$mc8',
    mc9                 = '$mc9',
    mc10                = '$mc10',
    email                = '$email',
    descriptif               = '$descriptif'
    
    
    WHERE id = '$id' " ;
     
      //exécution de la requête SQL:
      $requete = mysql_query($sql, $cnx) or die( mysql_error() ) ;
     
      //affichage des résultats, pour savoir si la modification a marchée:
      if($requete)
      {
        echo("La modification à été correctement effectuée") ;
      }
      else
      {
        echo("La modification à échouée") ;
      }
    ?>
    Et voici ce que me retourne la page web :
    You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'un fichier Excel (programme indispensable pour utiliser cette version) qui regro' at line 20
    Est-ce que quelqu'un aurait une idée comment échapper les apostrophes ?
    Merci pour vos réponses.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    En SQL, les chaines sont encadrées d'apostrophes. Il est donc nécessaire d’identifier les apostrophes à l'intérieur d'une chaine pour ne pas les confondre avec un marquer de fin de chaîne.
    Selon la norme du langage SQL, il suffit de doubler une apostrophe à l'intérieur d'une chaine pour la faire prendre en compte...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT 'C''est une chaine avec l''apostrophe doublée' FROM matable
    D'autres solutions existent en PHP (mais je ne suis pas développeur PHP)
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre émérite Avatar de Willy_k
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2011
    Messages
    541
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2011
    Messages : 541
    Par défaut
    Salut,

    faudrait appliquer mysql_real_escape_string sur vos variables (exemple $login = mysql_real_escape_string($_POST["login"]);).
    Mais à moins d'être contraint, on n'utilise plus cette API pour manipuler les BDD, il y a mieux PDO ou MYSQLI avec les requêtes préparées par exemple

  4. #4
    Membre régulier
    Homme Profil pro
    Webdesigner
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Par défaut
    Merci pour vos réponses. j'ai essayé ceci :
    descriptif = '$descriptif = 'mysql_real_escape_string($_POST['descriptif'])'
    Mais ça ne fonctionne pas j'ai l'erreur :
    Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in...
    Mais ça ne fonctionne pas. Au secours

  5. #5
    Membre émérite Avatar de Willy_k
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2011
    Messages
    541
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2011
    Messages : 541
    Par défaut
    Regardez mon code et faites de même sur les autres variables. J'ai appliqué la fonction sur $_POST['login'] par exemple

  6. #6
    Membre régulier
    Homme Profil pro
    Webdesigner
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Par défaut
    MERCI Willy_k après de multiples essais ça fonctionne à merveille.
    Suis super content d'être inscrit sur ce forum MERCI !!!!!!

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

Discussions similaires

  1. PRoblème d'apostrophe dans variable.
    Par jbidou88 dans le forum VBA Access
    Réponses: 2
    Dernier message: 05/06/2007, 14h57
  2. [MySQL] Problème d'apostrophes dans ma requête Update
    Par method_man dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 24/04/2007, 16h06
  3. [MySQL] Problème d'apostrophes dans insertion sql
    Par 12_darte_12 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 30/05/2006, 16h20
  4. problème d'apostrophe dans mes requetes
    Par kirian dans le forum Bases de données
    Réponses: 3
    Dernier message: 03/05/2006, 12h06
  5. insérer un apostrophe dans MySQL
    Par levraigreg dans le forum Débuter
    Réponses: 9
    Dernier message: 09/02/2006, 12h02

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