PHP MySQL - Enregistrer valeur checkbox
Résolu
Sinistrus
Messages postés
1010
Date d'inscription
Statut
Membre
Dernière intervention
-
Sinistrus Messages postés 1010 Date d'inscription Statut Membre Dernière intervention -
Sinistrus Messages postés 1010 Date d'inscription Statut Membre Dernière intervention -
Bonjour à tous !
Je souhaite enregistrer la valeur de mon checkbox dans ma table mysql. Pouvez-vous m'aider svp ?
Je souhaite enregistrer la valeur de mon checkbox dans ma table mysql. Pouvez-vous m'aider svp ?
<label><input type="checkbox" name="Fr_Pays_CI" id="Fr_Pays_CI" <?php if($data_fr['CI']==1) echo 'checked="checked" '; ?> />Côte d'Ivoire</label> <label><input type="checkbox" name="Fr_Pays_SN" id="Fr_Pays_SN" <?php if($data_fr['SN']==1) echo 'checked="checked" '; ?> />Sénégal</label>
$Fr_Pays_CI = $_POST["Fr_Pays_CI"]; $Fr_Pays_CI = mysql_real_escape_string($Fr_Pays_CI); $Fr_Pays_SN = $_POST["Fr_Pays_SN"]; $Fr_Pays_SN = mysql_real_escape_string($Fr_Pays_SN);
2 réponses
-
'lut, première étape: tu arrêtes d'utiliser l'extension MySQL, lis cet article pour savoir pourquoi; et le remplaces par MySQLi ou PDO.
(J'insiste, il faut que tu changes)
Deuxième étape: c'est un peu de PHP et de SQL.
L'élément de$_POST
correspondant à ta checkbox sera existant si la case est cochée, et non défini si elle ne l'est pas (doncisset($_POST['element'])
renverratrue
si la case est cochée).
En utilisant l'opérateur ternaire, on fait court et récupère les valeurs:$Fr_Pays_CI = isset($_POST["Fr_Pays_CI"]) ? "1" : "0"; $Fr_Pays_SN = isset($_POST["Fr_Pays_SN"]) ? "1" : "0";
Et comme tu utiliseras les requêtes préparées, pas d'atrocités genremysql_real_escape_string
(exemple PDO):$req = $bdd->prepare("INSERT INTO maTable (paysCi, paysSn) VALUES (:paysCi, :paysSn)"); $req->execute(array( ":paysCi" => $Fr_Pays_CI, ":paysSn" => $Fr_Pays_SN ));
from human import idiocy
del idiocy -
Merci gravgun, c'est la seconde fois que tu me dis de changer en MySQLi ou PDO
Je suis en train de le faire (promis) mais c'était pour avancer un peux sur cette correction (version 2).
La version 3 (actuelle) est en cours de maintenance !
En tout cas merci infiniment de m'avoir prévenu, je l'ignorais depuis ton précédent poste.