繁体   English   中英

多行保存到数据库表

[英]multiple row saving to DB table

我必须将多行数据保存到数据库表中。

我为此编写了代码。 但是,当我运行此代码时,两行将保存到db表的两行中,但每隔一行与最后一行的数据相同。

也就是说,最后一行数据将覆盖其他所有行数据。

$values = array();

if (isset($_POST['sub_save'])) {
    $row_count = $_POST['rowcount'];

    while ($row_count > 0) {
        for ($r = 1; $r <= 2; $r++) {
            $val = $_POST['txt'.$row_count.$r];
            $values[] = $val;
        }

        $row_count = $row_count - 1;
        $sql = "insert into timesheet_entry (name, address) values ('$values[0]', '$values[1]')";

        if (mysql_query($sql)) {
            echo "inserted";
        } else {
            echo "fail";
        }
    }
}

您无需在循环内重置values数组,因此values [0]和values [1]将始终具有第一个值。

if (isset($_POST['sub_save'])) {
    $row_count = $_POST['rowcount'];

    while ($row_count > 0) {
        $values = array();
        for ($r = 1; $r <= 2; $r++) {
            $val = $_POST['txt'.$row_count.$r];
            $values[] = $val;
        }

        $row_count = $row_count - 1;
        $sql = "insert into timesheet_entry (name, address) values ('$values[0]', '$values[1]')";

        if (mysql_query($sql)) {
            echo "inserted";
        } else {
            echo "fail";
        }
    }
}

在旁注中,我建议您查看PDO扩展名和参数化查询,因为不建议使用mysql_并且上面的代码容易受到SQL注入的攻击

您正在混合mysqlmysqli

$conn = mysqli_connect("localhost", "root", ""); 
$db = mysqli_select_db("dbname");

if (mysqli_query($sql)) {
   echo "inserted";
} else {
   echo "fail";
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM