php - 尝试使用 PHP 从 HTML 更新 MySQL;连接有效,但没有任何更新

标签 php html mysql mysqli pdo

我正在尝试构建一个 HTML 表单来使用 PHP 更新 MySQL 数据库。当我加载页面时,表格完全按照我的预期填充。但是,当我更改其中一个文本框中的某些内容并单击更新按钮时,更改不会发布到数据库中。它只是将数据库重新加载到我开始的表单/表中。作为引用,name 字段只是我用作主键/id 的 firstlast 的串联。我哪里出错了?

<html>
<body>

<?php

define( 'DB_SERVER', '123.234.345.456' );
define( 'DB_USERNAME', 'subad' );
define( 'DB_PASSWORD', 'password' );
define( 'DB_NAME', 'membership' );
$link = mysqli_connect( DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);
if ( $link === false ) {die( "ERROR: Could not connect. " . mysqli_connect_error() );}
$sql = 'SELECT * FROM members WHERE county = "abc"';
$result = mysqli_query( $link, $sql )or die( "Error With $sql" );

?>

<?php

if(isset($_POST['update'])){
try{$pdo = new PDO("mysql:host=123.234.345.456;dbname=membership", "subad", "password");
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);} 
catch(PDOException $e){die("ERROR: Could not connect. " . $e->getMessage());}
try{
  $first = $_POST['first'];
  $last = $_POST['last'];
  $phone = $_POST['phone'];
  $email = $_POST['email'];

$sql = "UPDATE members SET first=:first, last=:last, phone=:phone, email=:email WHERE name=:name";

$stmt = $pdo->prepare($sql);

$stmt->bindValue(":first", $first, PDO::PARAM_STR);
$stmt->bindValue(":last", $last, PDO::PARAM_STR);
$stmt->bindValue(":phone", $phone, PDO::PARAM_STR);
$stmt->bindValue(":email", $email, PDO::PARAM_STR);
$stmt->bindValue(":name", $name, PDO::PARAM_STR);

$stmt->execute();}
catch(PDOException $e){die("ERROR: Could not able to execute $sql. " . $e->getMessage());}

}

unset($pdo);?>

<form method="post" action="<?php $_PHP_SELF ?>">
<table width="400" border="0" cellspacing="1" cellpadding="2">
<tr>

<?php while($row = mysqli_fetch_array($result)) {$first = $row['first']; $last = $row['last']; $email = $row['email']; $phone = $row['phone']; $name = $row['name']; ?>

<td width="100"></td>
<td><?=$name?></td>
</tr>
<tr>
<td width="100">First</td>
<td><input name="first" type="text" value="<?=$first?>"></td>
</tr>
<tr>
<td width="100">Last</td>
<td><input name="last" type="text" value="<?=$last?>"></td>
</tr>
<tr>
<td width="100">Email</td>
<td><input name="email" type="text" value="<?=$email?>"></td>
</tr>
<tr>
<td width="100">Phone</td>
<td><input name="phone" type="text" value="<?=$phone?>"></td>
</tr>

<?php } ?>
<tr>
<td>
<input name="update" type="submit" id="update" value="Update">
</td>
</tr>
</table>
</form>

</body>
</html>

最佳答案

这对我来说不太合适

<form method="post" action="<?php $_PHP_SELF ?>">

我没有看到 $_PHP_SELF 的设置位置,并且您实际上并没有将其回显。另外,您可能正在考虑 $_SERVER["PHP_SELF"] 但这可能不是您想要的。尝试将操作留空,它将发布到当前网址:

<form method="post" action="">

关于php - 尝试使用 PHP 从 HTML 更新 MySQL;连接有效,但没有任何更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54101720/

相关文章:

php不显示重复的id

mysql - 使用主查询字段与子查询和子查询连接,其中条件

html - 在电子邮件中嵌入网页/框架

php - 网站在本地主机上和上传到服务器时显示不同

javascript - 如何在Javascript中点击按钮后显示div?

php - 存储 php ://input in a variable 的内容

python - MySQL-python 安装失败,退出状态为 1120

php - Symfony 5 如何在具有多对多关系的更新中自动发送当前用户

php - register_shutdown_function() 仍然输出原始错误信息

php - 比较时间范围并计算时间差