PHP代码信息

运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,不支持键盘输入语句但是拥有更高的运行速度,输出简洁明了 。 点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
证书查询页面 发布于:2021-04-18 01:13 array_multisort + trace 发布于:2021-04-15 15:35 再测试一波 发布于:2021-03-31 20:04 正则匹配网址 发布于:2021-03-28 01:17 php 数组按特定键排序 - array_multisort() 发布于:2021-03-24 15:25 php 多给数组循环赋值 - $arr[$k]['value'] 发布于:2021-03-24 15:27 简易求差集 发布于:2021-03-02 17:10 正则匹配组内 发布于:2021-03-02 13:02 解析OVI信息 发布于:2021-02-23 21:08 解析OVI信息 发布于:2021-02-23 16:24 参数作用域 发布于:2021-02-21 18:03 Static 作用域 发布于:2021-02-21 18:01 PHP global 关键字 发布于:2021-02-21 17:56 局部和全局作用域 发布于:2021-02-21 17:52 php中的注释 发布于:2021-02-21 17:25 我的第一个php 发布于:2021-02-21 17:01 exception测试 发布于:2021-02-20 16:13 后端测试代码 发布于:2021-02-07 13:53 PHP函数实战-汉诺塔递归算法 发布于:2021-02-04 21:24 PHP函数实战-PHP冒泡排序 发布于:2021-02-04 19:54 PHP匿名函数 发布于:2021-02-04 16:38 PHP递归调用 发布于:2021-02-03 01:32 PHP函数的嵌套 发布于:2021-02-03 00:41 PHP可变函数 发布于:2021-02-03 00:23 测试php的执行效率 发布于:2021-01-28 17:26 doReg-get.php 发布于:2021-01-20 00:04 秒换算为剩余天小时分秒 发布于:2021-01-19 10:56 柯里化函数的使用 发布于:2021-01-15 09:41 正则解析测试 发布于:2021-01-06 10:26 in 转sql 发布于:2021-01-05 15:45 echo var_dump 区别 - int(999) 发布于:2021-03-24 15:28 正则表达式排除单词里面的baidu 发布于:2020-12-28 18:54 php快速排序 - mt_rand() floor(count($arr)/2) array_merge() 发布于:2021-03-24 16:14 php二分查找 发布于:2021-01-03 16:24 工厂设计模式测试 发布于:2020-12-17 17:17 自定义强化 substr() 方法,以适用中文字符 发布于:2020-12-15 10:38 PHP 字符串变量 发布于:2020-12-11 14:44 PHP 常量 发布于:2020-12-11 14:38 PHP 5 数据类型 发布于:2020-12-11 14:31 斐波那契数列 发布于:2020-11-25 00:24 获取 url 参数 urlargs($str, $aname) - strstr() explode() 发布于:2021-03-24 15:42 人员人与人 发布于:2020-10-31 13:36 测试学习代码 发布于:2020-10-30 16:58 数组转换php 发布于:2020-10-28 17:02 魔术方法php 发布于:2020-10-19 20:07 echo语句 发布于:2020-10-14 15:31 网页数据处理 发布于:2020-10-14 13:47 session_destroy()的执行会销毁session_id() 发布于:2020-10-07 15:21 session_destroy()的执行会销毁session_id() 发布于:2020-09-28 09:45 网页数据处理 发布于:2020-09-17 08:49 [更多]
显示目录

插入多条数据

PHP MySQL 插入多条数据

一般情况下,INSERT 语句只能向 MySQL 数据库添加一条语句,而本文将介绍如何使用函数批量的向数据表插入多条数据。


使用 MySQLi 和 PDO 向 MySQL 插入多条数据

mysqli_multi_query() 函数可用来执行多条SQL语句。

以下实例向 "MyGuests" 表添加了三条新的记录:

实例 (MySQLi - 面向对象)

<?php  
$servername = "localhost";  
$username = "username";  
$password =  
"password";  
$dbname =  
"myDB";  

// 创建链接  
$conn =  
new mysqli($servername, $username, $password, $dbname);  

// 检查链接  

if ($conn->connect\_error) {  
die("Connection failed: " . $conn->connect\_error);  
}  


$sql = "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('John', 'Doe', 'john@example.com');";  

$sql .= "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('Mary', 'Moe', 'mary@example.com');";  

$sql .= "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('Julie', 'Dooley', 'julie@example.com')";  


if ($conn->multi\_query($sql) === TRUE) {  
echo "New  
records created successfully";  
} else {  
echo  
"Error: " . $sql . "  
" . $conn->error;  
}  

$conn->close();  
?>

请注意,每个SQL语句必须用分号隔开。

实例 (MySQLi - 面向过程)

<?php  
$servername = "localhost";  
$username = "username";  
$password =  
"password";  
$dbname =  
"myDB";  

// 创建链接  
$conn = mysqli\_connect($servername, $username, $password,  
$dbname);  

// 检查链接  

if (!$conn) {  
die("Connection  
failed: " . mysqli\_connect\_error());  
}  

$sql = "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('John', 'Doe', 'john@example.com');";  

$sql .= "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('Mary', 'Moe', 'mary@example.com');";  

$sql .= "INSERT INTO  
MyGuests (firstname, lastname, email)  

VALUES ('Julie', 'Dooley', 'julie@example.com')";  


if (mysqli\_multi\_query($conn, $sql)) {  
echo "New  
records  
created successfully";  
} else {  
echo "Error: "  
. $sql . "  
" . mysqli\_error($conn);  
}  

mysqli\_close($conn);  
?>

实例 (PDO)

<?php  
$servername = "localhost";  
$username = "username";  

$password = "password";  
$dbname =  
"myDBPDO";  

try {  
$conn = new PDO("mysql:host=$servername;dbname=$dbname",  
$username, $password);  

// set the PDO error mode to exception  
$conn->setAttribute(PDO::ATTR\_ERRMODE,  
PDO::ERRMODE\_EXCEPTION);  

// 开始事务  

$conn->beginTransaction();  
// SQL 语句  

$conn->exec("INSERT INTO MyGuests (firstname, lastname, email)  

VALUES ('John', 'Doe', 'john@example.com')");  

$conn->exec("INSERT INTO MyGuests (firstname, lastname, email)  

VALUES ('Mary', 'Moe', 'mary@example.com')");  

$conn->exec("INSERT INTO MyGuests (firstname, lastname, email)  

VALUES ('Julie', 'Dooley', 'julie@example.com')");  


// commit the transaction  
$conn->commit();  

echo "New records created successfully";  
}  
catch(PDOException $e)  
{  

// roll back the transaction if something failed  

$conn->rollback();  

echo $sql . "  
" . $e->getMessage();  
}  


$conn = null;  
?>

使用预处理语句

mysqli 扩展提供了第二种方式用于插入语句。

我们可以预处理语句及绑定参数。

mysql 扩展可以不带数据发送语句或查询到mysql数据库。 你可以向列关联或 "绑定" 变量。

Example (MySQLi 使用预处理语句)

<?php  
$servername = "localhost";  
$username = "username";  
$password =  
"password";  
$dbname =  
"myDB";  

// Create connection  
$conn =  
new mysqli($servername, $username, $password, $dbname);  

// Check connection  

if ($conn->connect\_error) {  
die("Connection failed: " . $conn->connect\_error);  
} else {  
$sql = "INSERT INTO  
MyGuests (firstname, lastname, email) VALUES(?, ?, ?)";  

// 为 mysqli\_stmt\_prepare() 初始化  
statement 对象  
$stmt =  
mysqli\_stmt\_init($conn);  

//预处理语句  

if (mysqli\_stmt\_prepare($stmt, $sql)) {  

// 绑定参数  

mysqli\_stmt\_bind\_param($stmt, 'sss', $firstname, $lastname, $email);  


// 设置参数并执行  

$firstname = 'John';  
$lastname  
\= 'Doe';  
$email =  
'john@example.com';  

mysqli\_stmt\_execute($stmt);  


$firstname = 'Mary';  
$lastname  
\= 'Moe';  
$email =  
'mary@example.com';  

mysqli\_stmt\_execute($stmt);  


$firstname = 'Julie';  

$lastname = 'Dooley';  
$email =  
'julie@example.com';  

mysqli\_stmt\_execute($stmt);  
}  
}  
?>

我们可以看到以上实例中使用模块化来处理问题。我们可以通过创建代码块实现更简单的读取和管理。

注意参数的绑定。让我们看下 mysqli_stmt_bind_param() 中的代码:

mysqli_stmt_bind_param($stmt, 'sss', $firstname, $lastname, $email);

该函数绑定参数查询并将参数传递给数据库。第二个参数是 "sss" 。以下列表展示了参数的类型。 s 字符告诉 mysql 参数是字符串。

可以是以下四种参数:

  • i - integer

  • d - double

  • s - string

  • b - BLOB

每个参数必须指定类型,来保证数据的安全性。通过类型的判断可以减少SQL注入漏洞带来的风险。

由JSRUN为你提供的PHP在线工具
        JSRUN提供的PHP在线运行,PHP 在线编译工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿

皮肤:

运行模式:

嵌入代码 iframe嵌入: