Quelqu'un peut-il m'aider à comprendre pourquoi cette requête de mise à jour ne met pas à jour les champs de ma base de données? J'ai ceci dans ma page php pour récupérer les valeurs actuelles de la base de données:
<?php
$query = mysql_query ("SELECT * FROM blogEntry WHERE username = 'bobjones' ORDER BY id DESC");
while ($row = mysql_fetch_array ($query))
{
$id = $row['id'];
$username = $row['username'];
$title = $row['title'];
$date = $row['date'];
$category = $row['category'];
$content = $row['content'];
?>
Voici mon formulaire HTML:
<form method="post" action="editblogscript.php">
ID: <input type="text" name="id" value="<?php echo $id; ?>" /><br />
Username: <input type="text" name="username" value="<?php echo $_SESSION['username']; ?>" /><br />
Title: <input type="text" name="udtitle" value="<?php echo $title; ?>"/><br />
Date: <input type="text" name="date" value="<?php echo $date; ?>"/><br />
Message: <textarea name = "udcontent" cols="45" rows="5"><?php echo $content; ?></textarea><br />
<input type= "submit" name = "edit" value="Edit!">
</form>
et voici mon 'editblogscript':
<?php
mysql_connect ("localhost", "root", "");
mysql_select_db("blogass");
if (isset($_POST['edit'])) {
$id = $_POST['id'];
$udtitle = $_POST['udtitle'];
$udcontent = $_POST['udcontent'];
mysql_query("UPDATE blogEntry SET content = $udcontent, title = $udtitle WHERE id = $id");
}
header( 'Location: index.php' ) ;
?>
Je ne comprends pas pourquoi ça ne marche pas.
Vous devez avoir des guillemets simples autour du contenu VARCHAR dans vos requêtes. Donc, votre requête de mise à jour devrait être:
mysql_query("UPDATE blogEntry SET content = '$udcontent', title = '$udtitle' WHERE id = $id");
De plus, il est mauvais de mettre à jour votre base de données directement avec le contenu d'un POST. Vous devez nettoyer vos données entrantes avec la fonction mysql_real_escape_string.
Sans savoir quelle est l'erreur réelle que vous obtenez, j'imagine qu'il manque des guillemets. essayez ce qui suit:
mysql_query("UPDATE blogEntry SET content = '$udcontent', title = '$udtitle' WHERE id = '$id'")
$ id = "1";
$ title = "phpmyadmin";
$sql= mysql_query("UPDATE table_name SET id ='".$id."', title = '".$title."',now() WHERE id = '".$id."' ");
fonction now () met à jour la date et l'heure actuelles.
note: For update query we have define the particular id otherwise it update whole table defaulty
Besoin d'ajouter un devis pour ce besoin d'utiliser l'opérateur point:
mysql_query("UPDATE blogEntry SET content = '".$udcontent."', title = '".$udtitle."' WHERE id = '".$id."'");
Tout d'abord, vous devez définir "ne fonctionne pas".
Deuxièmement, je suppose que votre champ de table 'contenu' est varchar/text, vous devez donc le mettre entre guillemets. content = '{$content}'
Et le dernier mais non le moindre: utilisez echo mysql_error()
directement après une requête pour déboguer.
Je suppose qu'il manque des citations. Essayez ce qui suit: J'espère que cela fonctionnera correctement
$ sql = mysql_query ("UPDATE nom_table SET id = '". $ u_id. "', name =". $ u_name. "', now () WHERE id =" ". $ u_id." ""); .//saut de ligne
vous devez écrire des guillemets simples, puis des guillemets doubles, puis des points avant le nom du champ et après, comme ça
mysql_query("UPDATE blogEntry SET content ='".$udcontent."', title = '".$udtitle."' WHERE id = '".$id."' ");
Mettre à jour une ligne ou une colonne d'un tableau
$update = "UPDATE daily_patients SET queue_status = 'pending' WHERE doctor_id = $room_no and serial_number= $serial_num";
if ($con->query($update) === TRUE) {
echo "Record updated successfully";
} else {
echo "Error updating record: " . $con->error;
}
<?php
require 'db_config.php';
$id = $_POST["id"];
$post = $_POST;
$sql = "UPDATE items SET title = '".$post['title']."'
,description = '".$post['description']."'
WHERE id = '".$id."'";
$result = $mysqli->query($sql);
$sql = "SELECT * FROM items WHERE id = '".$id."'";
$result = $mysqli->query($sql);
$data = $result->fetch_assoc();
echo json_encode($data);
?>
Essayez comme ceci dans la requête SQL, cela fonctionnera bien.
$sql="UPDATE create_test set url= '$_POST[url]' WHERE test_name='$test_name';";
Si vous devez mettre à jour plusieurs colonnes, utilisez le
$sql="UPDATE create_test set `url`= '$_POST[url]',`platform`='$_POST[platform]' WHERE test_name='$test_name';";