首页 >后端开发 >php教程 >如何使用 PDO_MYSQL 和 PDO_MYSQLND 在单个 PDO 语句中执行多个查询?

如何使用 PDO_MYSQL 和 PDO_MYSQLND 在单个 PDO 语句中执行多个查询?

Linda Hamilton
Linda Hamilton原创
2024-12-24 07:10:17143浏览

How Can I Execute Multiple Queries in a Single PDO Statement with PDO_MYSQL and PDO_MYSQLND?

PDO 支持使用 PDO_MYSQL 和 PDO_MYSQLND 进行多个查询

虽然 PDO 通常不允许在单个语句中进行多个查询,但扩展 PDO_MYSQL 和 PDO_MYSQLND 提供了对此的支持功能。

PDO_MYSQLND 已被替换PHP 5.3 中的 PDO_MYSQL,PDO_MYSQL 仍作为 MySQL PDO 的默认驱动程序。要使用 PDO 执行多个查询,必须满足以下要求:

  • PHP 版本 5.3 或更高版本
  • 启用 MySQL Native Driver (mysqlnd)
  • 模拟准备语句,其中 PDO::ATTR_EMULATE_PREPARES 设置为 1(默认值MySQL)

使用 exec()

exec() 方法可以在以下情况下执行多个查询:

$db = new PDO("mysql:host=localhost;dbname=test;charset=utf8mb4", 'root', '');
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0);

$sql = "DELETE FROM car; INSERT INTO car(name, type) VALUES ('car1', 'coupe'); INSERT INTO car(name, type) VALUES ('car2', 'coupe');";

$db->exec($sql);

此方法仅限于执行 SQL 语句常量值。

使用准备好的语句

当数据来源于PHP 变量,必须使用预准备语句:

$db = new PDO("mysql:host=localhost;dbname=test;charset=utf8mb4", 'root', '');
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$sql = "DELETE FROM car; INSERT INTO car(name, type) VALUES (:car1, :type1); INSERT INTO car(name, type) VALUES (:car2, :type2);";

$stmt = $db->prepare($sql);
$stmt->execute(["car1" => "brand1", "type1" => "coupe", "car2" => "brand2", "type2" => "coupe"]);

while ($stmt->nextRowset()) {
    echo $db->lastInsertId(); // as an example
}

此方法允许通过行集迭代来进行错误检查和收集查询结果。

模拟预准备语句的注意事项

使用模拟准备语句时,请确保 DSN 中的编码(自 PHP 5.3.6 起可用)与实际数据编码匹配。否则,某些编码可能存在 SQL 注入的可能性。

以上是如何使用 PDO_MYSQL 和 PDO_MYSQLND 在单个 PDO 语句中执行多个查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn