gpt4 book ai didi

php - 我的 php 表单仅保存表的最后一行。

转载 作者:行者123 更新时间:2023-11-29 17:36:04 25 4
gpt4 key购买 nike

我在表单 (new_tear.php) 中有一个表,它从单个用户获取数据。第一个列是从带有名称的数据库表 (ProfileTable) 中填充的。用户必须从下拉列表中为每行(每个名称)选择一个选项。当提交表单(POST 到tear_done.php)时,我想将每一行存储在我的数据库中。但是,我每次只看到最后一行发布

new_ter.php

<?php
$sqlT1 = "SELECT * FROM ProfileTable WHERE dept = 'T1'";
$queryT1 = mysqli_query($conn, $sqlT1);
if (!$queryT1) {
die ('SQL Error: ' . mysqli_error($conn));
}
?>
<form action="tear_done.php" method="post">
<table>
<?php
$no = 1;
while ($row = mysqli_fetch_array($queryT1))
{
echo '<tr>
<td>'.$no.'</td>
<td>'.$row['name'].'</td>
<td><select id="Dz_M" name="Dz_M">
<option value="4pm">4pm</option>
<option value="8am">8am</option>
<option value="Rest">Rest</option>
</select><br>
</td>
<td><select id="Dz_T" name="Dz_T">
<option value="4pm">4pm</option>
<option value="8am">8am</option>
<option value="Rest">Rest</option>
</select><br>
</td>
<td><select id="Dz_W" name="Dz_W">
<option value="4pm">4pm</option>
<option value="8am">8am</option>
<option value="Rest">Rest</option>
</select><br>
</td>
<td><select id="Dz_F" name="Dz_F">
<option value="4pm">4pm</option>
<option value="8am">8am</option>
<option value="Rest">Rest</option>
</select><br>
</td>
<td><select id="Dz_S" name="Dz_S">
<option value="4pm">4pm</option>
<option value="8am">8am</option>
<option value="Rest">Rest</option>
</select><br>
</td>
</tr>';
$no++;
$no_cont = $no;
}?>
</table>
<br>
<button value="save" type="submit" name="save">Save Tear</button>
</form>

tear_done.php

<?php
$sqlT1 = "SELECT * FROM ProfileTable WHERE dept = 'T1'";
$queryT1 = mysqli_query($conn, $sqlT1);
if (!$queryT1) {
die ('SQL Error: ' . mysqli_error($conn));
}
$no = 1;
while ($row = mysqli_fetch_array($queryT1))
{
$Name = $row ['name'];
$Dept = $row ['dept'];
$DZ_M = $_POST ["Dz_M"];
$DZ_T = $_POST ["Dz_T"];
$DZ_W = $_POST ["Dz_W"];
$DZ_F = $_POST ["Dz_F"];
$DZ_S = $_POST ["Dz_S"];

$sql = "INSERT INTO TearTable (name, Mdy, Tdy, Wdy, Fdy, Sdy, dept)
VALUES ('$Name', '$DZ_M', '$DZ_T', '$DZ_W', '$DZ_F', '$DZ_S', '$Dept')";

echo $no;
echo '<br>';
echo $sql; //for testing
echo '<br>';
$no++;
}
?>

我从 echo 中得到的是所有名称和部门都正确的 sql,但是其他字段 $DZ_M、$DZ_T 等仅重复从 new_tear.php 中的表中输入的最后一行。请问我缺少什么?

最佳答案

在While循环内只需连接插入查询字符串

while ($row = mysqli_fetch_array($queryT1))
{
......

$sql .= "INSERT INTO TearTable (name, Mdy, Tdy, Wdy, Fdy, Sdy, dept)
VALUES ('$Name', '$DZ_M', '$DZ_T', '$DZ_W', '$DZ_F', '$DZ_S', '$Dept');"; // Note .= and semicolon at the end

.....
}
// Outside the loop
execute your query here..

出于安全原因,您应该使用准备好的语句

关于php - 我的 php 表单仅保存表的最后一行。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50278477/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com