php table 一次更新多条记录
php table update multiple records at one time
我有一个 table 可以从用户 table 检索用户名和可用性状态。现在在我的测试数据库中我有 3 条记录。如果我尝试更改其中任何一个的可用性字段,请在更新中注明。
这是我的 availability.php
文件(第一行不断被截断):
<form method="POST" action="av_update.php">
<table cellspacing="0" width="50%" id="users" class="table table-striped table-hover table-responsive" style="margin-left:0;">
<thead class="alert-info">
<tr>
<th>ID</th>
<th>Username</th>
<th>Available?</th>
<th>Updated By</th>
</tr>
</thead>
<tbody>
<?php
require 'config/config.php';
$sql = $db_con->prepare("SELECT * FROM `users` ORDER BY `id` DESC");
$sql->execute();
while($row = $sql->fetch()){
?>
<tr>
<td><?php echo $row['id']; ?></td>
<td><?php echo $row['username']; ?></td>
<td><select name="availability" id="availability" style="width:150px;font-size:1.1em;">
<option style="background-color:rgb(0,0,150);color:rgb(200,200,200);font-size:1.2em;" value='<?php echo $row['availability']; ?>'><?php echo $row['availability']; ?></option>
<option value="Available">Available</option>
<option value="Not Available">Not Available</option>
</select></td>
<td><input class="form-control" id="av_updatedby" name="av_updatedby" value="<?php echo htmlspecialchars($_SESSION["username"]); ?>">
</tr>
<?php
}
?>
</tbody>
</table>
这是我的 av_update.php
文件:
require_once 'config/config.php';
if(ISSET($_POST['update'])){
try{
$id = $_GET['id'];
$availability = $_POST['availability'];
$av_updatedby = $_POST['av_updatedby'];
$db_con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$sql = "UPDATE `crm_users` SET `availability` = '$availability', `av_updatedby` = '$av_updatedby' WHERE `id` = '$id'";
$db_con->exec($sql);
}catch(PDOException $e){
echo $e->getMessage();
}
header("Location: av_updated.php");
die;
}
从其他表单更新任何其他字段以及从所有其他表单插入和删除数据都工作正常,所以我知道这不是连接文件。
任何有关获取代码以更新 table 的帮助将不胜感激。
您的表单操作必须转到 av_update.php?id=,因为您要从 $_GET 数组中获取该值。
此外,您应该清理和验证输入数据,否则您会将您的系统暴露于 SQL 注入和其他类型的攻击。
我有一个 table 可以从用户 table 检索用户名和可用性状态。现在在我的测试数据库中我有 3 条记录。如果我尝试更改其中任何一个的可用性字段,请在更新中注明。
这是我的 availability.php
文件(第一行不断被截断):
<form method="POST" action="av_update.php">
<table cellspacing="0" width="50%" id="users" class="table table-striped table-hover table-responsive" style="margin-left:0;">
<thead class="alert-info">
<tr>
<th>ID</th>
<th>Username</th>
<th>Available?</th>
<th>Updated By</th>
</tr>
</thead>
<tbody>
<?php
require 'config/config.php';
$sql = $db_con->prepare("SELECT * FROM `users` ORDER BY `id` DESC");
$sql->execute();
while($row = $sql->fetch()){
?>
<tr>
<td><?php echo $row['id']; ?></td>
<td><?php echo $row['username']; ?></td>
<td><select name="availability" id="availability" style="width:150px;font-size:1.1em;">
<option style="background-color:rgb(0,0,150);color:rgb(200,200,200);font-size:1.2em;" value='<?php echo $row['availability']; ?>'><?php echo $row['availability']; ?></option>
<option value="Available">Available</option>
<option value="Not Available">Not Available</option>
</select></td>
<td><input class="form-control" id="av_updatedby" name="av_updatedby" value="<?php echo htmlspecialchars($_SESSION["username"]); ?>">
</tr>
<?php
}
?>
</tbody>
</table>
这是我的 av_update.php
文件:
require_once 'config/config.php';
if(ISSET($_POST['update'])){
try{
$id = $_GET['id'];
$availability = $_POST['availability'];
$av_updatedby = $_POST['av_updatedby'];
$db_con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$sql = "UPDATE `crm_users` SET `availability` = '$availability', `av_updatedby` = '$av_updatedby' WHERE `id` = '$id'";
$db_con->exec($sql);
}catch(PDOException $e){
echo $e->getMessage();
}
header("Location: av_updated.php");
die;
}
从其他表单更新任何其他字段以及从所有其他表单插入和删除数据都工作正常,所以我知道这不是连接文件。
任何有关获取代码以更新 table 的帮助将不胜感激。
您的表单操作必须转到 av_update.php?id=,因为您要从 $_GET 数组中获取该值。
此外,您应该清理和验证输入数据,否则您会将您的系统暴露于 SQL 注入和其他类型的攻击。