使用 PDO 准备好的语句插入多行
使用单个准备好的语句将多行插入数据库不仅是可能的,而且推荐用于它的效率和安全性。
单个插入的方法查询
第一种方法涉及使用具有多个值的单个 INSERT 查询:
INSERT INTO Table (col1, col2, col3) VALUES ('abc', 'def', 'ghi'), ('abc', 'def', 'ghi'), ('abc', 'def', 'ghi'), ('abc', 'def', 'ghi'), ('abc', 'def', 'ghi') -- and so on...
要使用 PDO 执行此查询,您可以按照以下步骤操作:
$query = "INSERT INTO Table (col1, col2, col3) VALUES (?, ?, ?), (?, ?, ?), (?, ?, ?) "; $params = array('abc', 'def', 'ghi', 'abc', 'def', 'ghi', 'abc', 'def', 'ghi'); $stmt = DB::getInstance()->prepare($query); $stmt->execute($params);
使用单独插入查询的方法
如果要插入的行数太大,您可能需要执行单独的插入查询:
$query = "INSERT INTO Table (col1, col2, col3) VALUES (".implode(',', $args).")"; $stmt = $pdo->prepare($query); foreach ($rows as $row) { $stmt->execute($row); }
这种方法可确保每行单独插入,最大限度地降低插入过程中出现问题的风险。
结论
无论您使用具有多个值的单个插入查询还是单独的插入查询,PDO 准备好的语句都提供了高效且安全的方法用于将多行插入数据库。选择正确的方法取决于应用程序和数据库的具体要求。
以上是如何使用 PDO 准备语句将多行插入数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!