我在一个简单的 PHP MySQL 项目中遇到问题。当我尝试从选择选项中获取记录时,它只提供 ID。我也希望传递来自选择的值。<form class="form-style-9" method="POST" action="function.php?type=updatedistrict">`` <ul> <li>ID: <input type="hidden" name="dist_id" class="field-style field-full align-none" value="<?php echo $ids;?>" readonly /> </li> <li>District Name: <input type="text" name="name" class="field-style field-full align-none" value="<?php echo $names;?>" /> </li> <li>Postal Code: <input type="text" name="code" class="field-style field-full align-none" value="<?php echo $codes;?>"/> </li> <li>Province <select name="province_id" class="form-control"> <option value="">Select Province</option> <?php $sql = mysqli_query($conn, "SELECT id, province From province"); $row = mysqli_num_rows($sql); while ($row = mysqli_fetch_array($sql)){ echo "<option value='". $row['id'] ."'>" .$row['province'] ."</option>" ; } ?> </select> <li> <input type="submit" value="Update" name="submit" /> </li> </ul> </form>这是更新功能代码:case 'updateprovince':if (isset($_POST['submit'])) { $id = $_POST['dist_id']; $prov_id= $_POST['province_id']; $query=$conn->query("UPDATE province SET province='$prov_id' where id='$id'"); if ($query) { echo '<script> window.location.replace("province.php"); </script>'; } else { echo "issue"; } }break;
1 回答
GCT1015
TA贡献1827条经验 获得超4个赞
您可以通过以下方式发布您的省份名称而不是 ID:
echo "<option value='". $row['province'] ."'>" .$row['province'] ."</option>" ;
然后,您的$_POST['province_id']将包含省份值而不是当前 ID。
通过您的选项传递 id 和值(如果您需要保留 id 进行某些额外处理)的方法如下:
echo "<option value='". $row['id'] . '|'. $row['province'] ."'>" .$row['province'] ."</option>" ;
然后在提交后,您只需用“|”将两者分开 分隔符。
if (isset($_POST['submit'])) {
$id = $_POST['dist_id'];
$province = explode('|', $_POST['province_id']);
$province_id = $province[0]
$province_name = $province[1]
- 1 回答
- 0 关注
- 114 浏览
添加回答
举报
0/150
提交
取消