CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

PHP probleme guillemets requete SQL

jas75
jas75
Niveau 7
22 mars 2016 à 15:08:28

Bonjour la communauté je viens a vous aujourd'hui car j'ai un probleme au niveau de l'insertion en bdd. J'ai donc une fonction insert qui marche bien sauf quand mon formulaire contient une quote qui sera evidemment mal interpreté. Mon prof m'a dit de faire une requete préparée ce que j'ai donc fait mais le probleme persiste. Voici mon code

jas75
jas75
Niveau 7
22 mars 2016 à 15:08:46

function insert($table,$data){
    global $bdd;
    $sql="INSERT INTO $table(";
    foreach ($data as $key => $value) {
        $sql.=$key.",";
    }
    $sql=substr($sql, 0,-1);
    $sql.=") VALUES (";
    foreach ($data as $value) {
        $sql.="'".$value."',";
    }
    $sql=substr($sql, 0,-1);
    $sql.=")";
    $insert=$bdd->prepare($sql);
    $insert->execute();

}
TheRealMarco
TheRealMarco
Niveau 13
22 mars 2016 à 15:23:38

J'aime bien quand on nous montre l'erreur aussi. :noel:

jas75
jas75
Niveau 7
22 mars 2016 à 15:27:01

Fatal error: Uncaught PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'pi,klfds','150')' at line 1 in /Users/jason/Desktop/PHPMYSQL/feuj/application/models/bdd.php:16 Stack trace: #0 /Users/jason/Desktop/PHPMYSQL/feuj/application/models/bdd.php(16): PDOStatement->execute() #1 /Users/jason/Desktop/PHPMYSQL/feuj/application/templates/pages/log-profil.php(6): insert('posts', Array) #2 /Users/jason/Desktop/PHPMYSQL/feuj/index.php(31): require('/Users/jason/De...') #3 {main} thrown in /Users/jason/Desktop/PHPMYSQL/feuj/application/models/bdd.php on line 16

jas75
jas75
Niveau 7
22 mars 2016 à 15:27:51

j'ai fait un var_dump de $sql et evidemment l'erreur est que dans la requete il y a une quote en trop

Sous forums
  • Aide à l'achat Mac
  • Création de sites web
  • Internet
  • Macintosh
  • Création de Jeux
  • Linux
  • Programmation
  • Steam Deck
  • Hardware
La vidéo du moment