虽然 PDO 通常不允许在单个语句中进行多个查询,但某些扩展提供了此功能:
PDO_MYSQLND 已替换PHP 5.3 中的 PDO_MYSQL。它充当 MySQL PDO 的默认驱动程序。此扩展支持同时执行多个查询,前提是满足以下条件:
使用 exec
对于常量值的简单查询,可以使用 exec() 方法:
$db = new PDO(...); $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0); $sql = "..."; $db->exec($sql);
使用语句
对于带有变量的查询数据时,使用预准备语句:
$db = new PDO(...); $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1); $sql = "..."; $stmt = $db->prepare($sql); $stmt->execute([...]);
记住循环查询结果以检查错误或收集数据。
使用模拟预准备语句时,确保在 DSN 中指定正确的编码(在 PHP 5.3.6 及更高版本中可用)。不正确的编码可能会带来使用异常字符集的 SQL 注入的轻微风险。
以上是如何使用 PDO_MYSQL 或 PDO_MYSQLND 在单个 PDO 语句中执行多个查询?的详细内容。更多信息请关注PHP中文网其他相关文章!