Problème SQL/PHP
Résolu
Autumn`Tears
Messages postés
1054
Date d'inscription
Statut
Membre
Dernière intervention
-
Autumn`Tears Messages postés 1054 Date d'inscription Statut Membre Dernière intervention -
Autumn`Tears Messages postés 1054 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
J'ai un script PHP qui me permet de supprimer un élément dans ma base de donnée. Il fonctionne très bien, sauf pour supprimer un élément contenant le caractère '. Y-a-t-il une solution pour résoudre ce problème ? Merci !
J'ai un script PHP qui me permet de supprimer un élément dans ma base de donnée. Il fonctionne très bien, sauf pour supprimer un élément contenant le caractère '. Y-a-t-il une solution pour résoudre ce problème ? Merci !
A voir également:
- Problème SQL/PHP
- Easy php - Télécharger - Divers Web & Internet
- Expert php pinterest - Télécharger - Langages
- Logiciel sql - Télécharger - Bases de données
- Alert php ✓ - Forum PHP
- Retour a la ligne php ✓ - Forum PHP
12 réponses
Tu peux soit échapper les caractères avec addslashes ou bien mettreta chaine entre deux `.
Exemples :
Exemples :
$req=mysql_query('DELETE FROM Carte WHERE Nom=`'.$_SESSION['selection3'].'`') or die('Erreur'.mysql_error());Ou
$req=mysql_query('DELETE FROM Carte WHERE Nom="'.addslashes($_SESSION['selection3']).'"') or die('Erreur'.mysql_error());
C'est que la deuxième fonctionne mais dans ta base de données, tu n'as pas utiliser la fonction addslashes alors tu as ça dans ta base de données :
Et tu cherche à supprimer :
Essaye avec ça :
Coucou, je m'casse
Et tu cherche à supprimer :
Coucou, je m\'casse
Essaye avec ça :
$req=mysql_query("DELETE FROM Carte WHERE Nom=`".$_SESSION['selection3']."`") or die('Erreur'.mysql_error());
J'ai réussi à contourner ce maudit problème finalement.
Le problème venait de la valeur retournée par mon $_POST qui ne renvoyait à la base que autumn et non autumn'tears.
Dire que la solution était juste là...
Enfin, merci tout de même pour votre aide, ça m'a permis d'apprendre de nouvelles fonctions !
Le problème venait de la valeur retournée par mon $_POST qui ne renvoyait à la base que autumn et non autumn'tears.
Dire que la solution était juste là...
Enfin, merci tout de même pour votre aide, ça m'a permis d'apprendre de nouvelles fonctions !
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Échappe le ' par un anti-slashe comme ceci : \'
Si c'est une variable qui contient cet apostrophe, utilise addslashes.
Si c'est une variable qui contient cet apostrophe, utilise addslashes.
Sans aucun code c'est difficile à être explicite mais à priori tu devrais regarder du côté des caractères d'échappement, soit de PHP, soit de ton SGBD, soit des deux.
l'anti-slash en PHP, le simple quote pour PgSQL....
Sachant que, bien entendu, il existe des fonctions qui sont capables d'échapper les méta-caractères d'une chaîne. Encore faut-il chercher et trouver la bonne, chaque langage a les siens ...
l'anti-slash en PHP, le simple quote pour PgSQL....
Sachant que, bien entendu, il existe des fonctions qui sont capables d'échapper les méta-caractères d'une chaîne. Encore faut-il chercher et trouver la bonne, chaque langage a les siens ...
Bon, je poste la partie de code qui gère la suppression :
$req=mysql_query("DELETE FROM Carte WHERE Nom='".$_SESSION['selection3']."'") or die("Erreur".mysql_error());
Sachant que dans la base, le champ Nom est la clé primaire.
Le problème se fait au niveau de mon $_SESSION['selection3'] qui ne fonctionne pas si je veux supprimer l'élément autumn'tears, par exemple.
$req=mysql_query("DELETE FROM Carte WHERE Nom='".$_SESSION['selection3']."'") or die("Erreur".mysql_error());
Sachant que dans la base, le champ Nom est la clé primaire.
Le problème se fait au niveau de mon $_SESSION['selection3'] qui ne fonctionne pas si je veux supprimer l'élément autumn'tears, par exemple.
J'ai testé dans un echo, il ne renvoie que la valeur de autumn. Même résultat avec addashes.
Je suis à court d'idée...
Je suis à court d'idée...
bonjour :)
sinon, essai ca :
$req=mysql_query("DELETE FROM Carte WHERE Nom=`".$_SESSION['selection3'])."`") or die("Erreur".mysql_error());
sinon, essai ca :
$req=mysql_query("DELETE FROM Carte WHERE Nom=`".$_SESSION['selection3'])."`") or die("Erreur".mysql_error());
Bonjour,
Ni l'une ni l'autre des solutions ne fonctionnent, je viens de les tester. Pour la première elle me renvoie une erreur, et la seconde ne me renvoie pourtant aucune erreur.
Ni l'une ni l'autre des solutions ne fonctionnent, je viens de les tester. Pour la première elle me renvoie une erreur, et la seconde ne me renvoie pourtant aucune erreur.