J'essaie simplement de mettre à jour plusieurs valeurs de mon tableau. Quelle serait la meilleure façon de s'y prendre? Voici le code actuel:
$postsPerPage = $_POST['postsPerPage'];
$style = $_POST['style'];
mysql_connect ("localhost", "user", "pass") or die ('Error: ' . mysql_error());
mysql_select_db ("db");
mysql_query("UPDATE settings SET postsPerPage = $postsPerPage WHERE id = '1'") or die(mysql_error());
L'autre mise à jour que je veux inclure est:
mysql_query("UPDATE settings SET style = $style WHERE id = '1'") or die(mysql_error());
Merci!
Ajoutez vos multiples colonnes avec des séparations par virgule:
UPDATE settings SET postsPerPage = $postsPerPage, style= $style WHERE id = '1'
Cependant, vous ne désinfectez pas vos entrées ?? Cela signifierait que tout pirate informatique aléatoire pourrait détruire votre base de données. Voir cette question: Quelle est la meilleure méthode pour nettoyer les entrées utilisateur avec PHP?
Aussi, le style est-il un nombre ou une chaîne? Je suppose une chaîne, il faudrait donc la citer.
Virgule séparer les valeurs:
UPDATE settings SET postsPerPage = $postsPerPage, style = $style WHERE id = '1'"
Si vous utilisez pdo, cela ressemblera à
$sql = "UPDATE users SET firstname = :firstname, lastname = :lastname WHERE id= :id";
$query = $this->pdo->prepare($sql);
$result = $query->execute(array(':firstname' => $firstname, ':lastname' => $lastname, ':id' => $id));
Je suppose que vous pouvez utiliser:
$con = new mysqli("localhost", "my_user", "my_password", "world");
$sql = "UPDATE `some_table` SET `txid`= '$txid', `data` = '$data' WHERE `wallet` = '$wallet'";
if ($mysqli->query($sql, $con)) {
print "wallet $wallet updated";
}else{
printf("Errormessage: %s\n", $con->error);
}
$con->close();