1

再会。

<input type="text" name="title">
<input type="text" name="name[]">
<input type="text" name="name[]">

<?php
if(isset($_POST['submit']){
    $title = $_POST['title'];
    $name = $_POST['name'];

    $add = "INSERT INTO books (title, name) VALUES ('$title','$name')";
}
?>

这段代码如何工作?它应该同时插入相同的标题和不同的名称。谢谢你。

样本表格

我希望记录更新如下:

---------------------------------

|--bookID--|--Title--|--Author--|

|----1-----|---one---|----me----|

|----2-----|---two---|---you----|

---------------------------------

4

4 回答 4

1

$_POST['name']是一个带有 key 的数组01......所以在你的例子中你有:

 //This is just an example
 foreach($_POST['name'] as $name) {

 }

希望这可以帮助。

于 2018-07-24T08:49:58.007 回答
0

Atul Vekariya 示例是正确的,但您还需要在循环中执行查询。这就是为什么这个例子不适合你。

if(is_array($_POST['name']) && !empty($_POST['name'])) {
    foreach($_POST['name'] as $name) {
        $add = "INSERT INTO books (title, name) VALUES ('$title','$name')";

        //execute query here. mysqli_query($add) or PDO::query
    }
}
于 2018-07-26T08:15:30.380 回答
0

请检查以下代码

if(is_array($_POST['name']) && !empty($_POST['name'])) {
    foreach($_POST['name'] as $name) {
        $add = "INSERT INTO books (title, name) VALUES ('$title','$name')";
    //execute query here. mysqli_query($add) or PDO::query
    }
}
于 2018-07-24T09:04:46.847 回答
0

在寻找不同的解决方案之后。这是有效的。谢谢大家的帮助。

<?php
include_once 'config/connect.php';

if($_SERVER["REQUEST_METHOD"] == "POST"){
    $title = $_POST['title'];
    $name = $_POST['name'];
    $length = count($name);
    $addBook = "INSERT INTO books (title,name) VALUES ";
    for($i=0; $i<$length; $i++){
        $addBook .= "('$title','$name[$i]'),";
    }
    $addBook = rtrim($addBook, ',');

    if($conn->query($addBook) === TRUE) {
        echo "Success";
    } else {
        echo "Error: ".$addBook."<br>".$conn->error;
    }

}
?>

<form action="addBook.php" method="POST">
    Title: <input type="text" name="title">
    <br/>
    Authors: <input type="text" name="name[]"> <input type="text" name="name[]"> 
    <br/>
    <input type="submit" name="submit">
</form>
于 2018-07-30T01:49:51.963 回答