Im trying to get the input from a form and delete the table data then display the the updated table but i get a blank page I don't know what could be the problem any help would be appericiated here's my code:
<html>
<body>
<?php
$mysqli = new mysqli("xxxxx", "xxxxxx", "xxxxx", "xxxxxx");
/* check connection */
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
//----------------------------------------------------------------------------------//
$name = $_POST['Car_ID'];
if ($stmt = $mysqli->prepare("delete from CARS where name=?")) {
// Bind the variable to the parameter as a string.
$stmt->bind_param("s", $name);
// Execute the statement.
$stmt->execute();
echo "Deleted data successfully\n";
// Close the prepared statement.
$mysqli->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$result = $db->prepare("SELECT id, Doors, TRANSMISSION, Fuel_type, Engine_Size, Total FROM CARS");
$result->execute();
while ($row = $result->fetch(PDO::FETCH_ASSOC)){
$doors=$row["Doors"];
$engine=$row["Engine_Size"];
$total=$row["Total"];
$trans=$row["Transmission"];
}
?>
<table>
<tr>
<td><?php echo $doors; ?></td>
<td><?php echo $engine; ?></td>
<td><?php echo $total; ?></td>
<td><?php echo $trans; ?></td>
</tr>
<?php } ?>
</table>
</body>
</html>
You're mixing mysqli
with PDO
$mysqli->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
and you're passing $db
where it (theoretically) should be $mysqli
$result = $db->prepare("SELECT id, Doors, TRANSMISSION, Fuel_type, Engine_Size, Total, DATE_INITIATED, AGE, PARTNO, QTY, DESCRIPTION, LOC FROM CARS");
where theoretically, it should be
$result = $mysqli->prepare("SELECT id, Doors, TRANSMISSION, Fuel_type, Engine_Size, Total, DATE_INITIATED, AGE, PARTNO, QTY, DESCRIPTION, LOC FROM CARS");
since your DB connection is:
$mysqli = new mysqli("xxxxx", "xxxxxx", "xxxxx", "xxxxxx");
However, your DB connection however should resemble:
$mysql_hostname = 'xxx';
$mysql_username = 'xxx';
$mysql_password = 'xxx';
$mysql_dbname = 'xxx';
$db = new PDO("mysql:host=$mysql_hostname;dbname=$mysql_dbname", $mysql_username, $mysql_password);
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
You can't do this:
$stmt->bind_param("s", $name);
You're using PDO remember? (or are you?) Take your pick, is it mysqli
or PDO?
You most likely want to do:
// $stmt = $db->prepare("delete from CARS where name=:value");
if ($stmt = $db->prepare("delete from CARS where name=:value")) {
// Bind variables to your statement
$stmt->bindParam(':value', $name);
... }
Collected from the Internet
Please contact [email protected] to delete if infringement.
Comments