使用$ _GET从URL和更新数据库中抓取具有相同的ID多个值(Use $_GET to grab

2019-11-01 21:27发布

我已经跑进试图用一系列的复选框,从列表中选择多个设备部件,以便用户可以再“签”的项目的问题。

下面是提交数据时我的第一页

        <div class="list"><form action="remove.php" enctype="multipart/form-data"
         name="form" id="form">

<input type="submit" style="color: white; background: none repeat scroll 0% 0%
 black; font-size: 21px; padding-bottom: 30px; position: fixed; height: 30px;
 right: 0px; margin-right: 1px;"
     value="Checkout" />
    <table cellpadding="0" cellspacing="0" border="0" id="table">
<thead>
<tr>
<th>Select</th>
<th>Equipment Number</th>
<th>Equipment</th>
</tr></thead>
    <tbody>
  <? $sql    = "SELECT * FROM equipment";
    $result = mysql_query($sql);
    while ($rows = mysql_fetch_array($result)) {
        if ($rows['equip_avail'] == "1") {
?>

<tr>
<td width="5%"><input type="checkbox" name="equip_id" value="<?php echo 
$rows['equip_id']; ?>" /></td>
<td width="13%"><?php echo $rows['equip_num'];?></td>
<td width="20%"><?php echo $rows['equipment']; ?></td>
</tr>
<?php
        }
    }
    echo '</tbody></table></form></div>';
}
?>

这里是它确认页面,然后从URL的数据,和帖子,我需要这个页面能够采取从URL多个“equip_id”(或其他解决办法,我目前尚不知情),并更新信息正确的“USER_ID”。 我可以多出现在URL,但只有最后一个被抓住。

    $id = $_SESSION['id'];
$equip_id =$_GET['equip_id'];
$sql = mysql_query("SELECT * FROM equipment WHERE equip_id='$equip_id'"); 
while($row = mysql_fetch_array($sql)){
    $equip_id = $row['equip_id'];
    $equipment = $row["equipment"];
    $equip_num = $row["equip_num"];
    $equip_avail = $row["equip_avail"];
    $user_id= $row['user_id'];
}

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $user_id = $_POST['user_id'];
    $equip_avail = $_POST['equip_avail'];
    $sql = mysql_query("UPDATE equipment SET user_id='$user_id', 
    equip_avail='$equip_avail' WHERE equip_id='$equip_id'"); 

    header("Location: equipment_checkout.php");
exit();
} // close if post
?>

这是HTML

     <table height="225px">
<form action="<? echo 'remove.php?equip_id='.$equip_id.' '?>"
   method="post" enctype="multipart/form-data" name="form" id="form">
<td width="423" valign="top"><h2>Equipment: <?php echo $equipment?></h2>
    <h2>Equipment Number: <?php echo $equip_num?></h2>
<input name="equip_avail" type="hidden" id="equip_avail" value="0" size="30"
maxlength="24" />
<?if(($_SESSION['id'] !=='0') && ($uaccounttype !== 'e') &&
($uaccounttype !== 'd')){?>
<input name="user_id" type="hidden" id="user_id" value="<? echo $_SESSION['id']
?>" size="30" maxlength="64" />
    </tr><?} else {
        $sql="SELECT * FROM members WHERE accounttype IN ('b', 'c', 'e')";
    $result = mysql_query($sql);            
        ?> 
<h2>Select Employee: <select name="user_id" id="user_id">
<?  $count = 1;
    while($rows = mysql_fetch_array($result)){
        if($count == 1){?>
<option value="<?echo $rows['id'];?>">
<?  echo $rows['firstname']. " ". $rows['lastname'] ;}} ?></option>
</select></h2>
<?}?>       
    <input name="Submit" type="submit" value="Check Out"/>
    </br>
   </td>
  </form>
</table>
</div>

我需要的最后一部分做的是为每一个“equip_id”从第一页选择,在这里显示,然后将数据库与正确的“USER_ID”每个选定的设备进行更新。 就像我说的,我可以得到一个在同一时刻更新,我只是需要让这个大量可编辑。

**注:我知道这是不发送数据的安全的方式,如果对如何使这个更安全,我会喜欢它的任何建议。 谢谢!!!!

Answer 1:

您需要输入名称的数组( equip_id[]

<input type="checkbox" name="equip_id[]" value="<?php echo $rows['equip_id']; ?>" />

然后$_GET['equip_id']将数组$rows['equip_id']秒。

虽然它肯定会更好地使用$_POST



Answer 2:

这是我想出了基于答案,并发布所有选择的设备的基础上,“equip_id”,然后相应地更新设备。 我在这里发帖,以防万一别人是寻找相同的解决方案。

我更新了这条线,你建议

<input type="checkbox" name="equip_id[]" value="<?php echo $rows['equip_id']; ?>"

这是第二页,上面写着从第一个数据。

<?foreach ($_GET['equip_id'] as $equip_id) {



$sql = mysql_query("SELECT * FROM equipment WHERE equip_id='$equip_id'") or
die(mysql_error()); 
while($row = mysql_fetch_array($sql)){
$equipment = $row["equipment"];
$equip_num = $row["equip_num"];
$equip_avail = $row["equip_avail"];
$user_id= $row['user_id'];
$equip_id= $row['equip_id'];}?>
<td width="423" valign="top"><h2>Equipment:
<?php echo $equipment?></h2>
    <h2>Equipment Number:<?php echo "$equip_num"?></h2>
<?}

这是张贴数据的一部分。

if ($_SERVER['REQUEST_METHOD'] === 'POST'){
foreach ($_GET['equip_id'] as $equip_id) {
    $equip_id = $equip_id ;
    $user_id = $_POST['user_id'];
$sql = mysql_query("UPDATE equipment SET user_id='$user_id', equip_avail='0'
WHERE equip_id='$equip_id'") or die(mysql_error());} 
header("Location: member_equipment.php?id='$id'");
exit();}


文章来源: Use $_GET to grab multiple values with same id from URL and update DB