php form 多行数据 写入mysql
时间: 2023-10-31 10:05:38 浏览: 114
您可以使用以下步骤将多行数据从 PHP 表单写入 MySQL 数据库:
1. 建立与数据库的连接。您可以使用 mysqli 或 PDO 扩展来连接 MySQL 数据库。以下是使用 mysqli 扩展连接数据库的示例代码:
```php
// 数据库连接参数
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";
// 创建连接
$conn = mysqli_connect($servername, $username, $password, $dbname);
// 检查连接是否成功
if (!$conn) {
die("连接失败: " . mysqli_connect_error());
}
```
2. 获取表单数据。您可以使用 $_POST 或 $_GET 超全局变量获取表单数据。以下是一个示例表单:
```html
<form method="post" action="insert.php">
<label for="name">姓名:</label>
<input type="text" name="name[]" id="name"><br>
<label for="age">年龄:</label>
<input type="text" name="age[]" id="age"><br>
<label for="gender">性别:</label>
<input type="radio" name="gender[]" value="male" id="gender-male">男
<input type="radio" name="gender[]" value="female" id="gender-female">女<br>
<br>
<label for="name">姓名:</label>
<input type="text" name="name[]" id="name"><br>
<label for="age">年龄:</label>
<input type="text" name="age[]" id="age"><br>
<label for="gender">性别:</label>
<input type="radio" name="gender[]" value="male" id="gender-male">男
<input type="radio" name="gender[]" value="female" id="gender-female">女<br>
<br>
<!-- 可以添加更多的行 -->
<input type="submit" value="提交">
</form>
```
注意:在该示例表单中,每个字段都有一个数组名称。这是因为我们可以使用多个字段添加多个行。
3. 处理表单数据。在 insert.php 文件中,您可以使用以下代码来处理表单数据:
```php
// 处理表单数据
$name = $_POST['name'];
$age = $_POST['age'];
$gender = $_POST['gender'];
// 将数据组合成一个二维数组
$data = array();
foreach ($name as $key => $value) {
$data[] = array(
'name' => $value,
'age' => $age[$key],
'gender' => $gender[$key]
);
}
```
4. 插入数据到数据库。在 insert.php 文件中,您可以使用以下代码将数据插入到数据库中:
```php
// 插入数据到数据库
foreach ($data as $row) {
$sql = "INSERT INTO myTable (name, age, gender) VALUES ('" . $row['name'] . "', " . $row['age'] . ", '" . $row['gender'] . "')";
if (mysqli_query($conn, $sql)) {
echo "数据插入成功!";
} else {
echo "Error: " . $sql . "<br>" . mysqli_error($conn);
}
}
```
注意:在该示例代码中,我们使用了 MySQLi 扩展来执行 SQL 语句。请注意避免 SQL 注入攻击。
以上就是将多行数据从 PHP 表单写入 MySQL 数据库的步骤。
阅读全文