use*_*840 10 php mysql pdo sql-insert
比如,我们在表中插入了多行:
$rows = [(1,2,3), (4,5,6), (7,8,9) ... ] //[ array of values ];
Run Code Online (Sandbox Code Playgroud)
使用PDO:
$sql = "insert into `table_name` (col1, col2, col3) values (?, ?, ?)" ;
Run Code Online (Sandbox Code Playgroud)
现在,您应该如何继续插入行?像这样?
$stmt = $db->prepare($sql);
foreach($rows as $row){
$stmt->execute($row);
}
Run Code Online (Sandbox Code Playgroud)
或者,像这样?
$sql = "insert into `table_name` (col1, col2, col3) values ";
$sql .= //not sure the best way to concatenate all the values, use implode?
$db->prepare($sql)->execute();
Run Code Online (Sandbox Code Playgroud)
哪种方式更快更安全?插入多行的最佳方法是什么?
您至少有以下两个选项:
$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];
$sql = "insert into `table_name` (col1, col2, col3) values (?,?,?)";
$stmt = $db->prepare($sql);
foreach($rows as $row)
{
$stmt->execute($row);
}
OR:
$rows = [(1,2,3), (4,5,6), (7,8,9) ... ];
$sql = "insert into `table_name` (col1, col2, col3) values ";
$paramArray = array();
$sqlArray = array();
foreach($rows as $row)
{
$sqlArray[] = '(' . implode(',', array_fill(0, count($row), '?')) . ')';
foreach($row as $element)
{
$paramArray[] = $element;
}
}
// $sqlArray will look like: ["(?,?,?)", "(?,?,?)", ... ]
// Your $paramArray will basically be a flattened version of $rows.
$sql .= implode(',', $sqlArray);
$stmt = $db->prepare($sql);
$stmt->execute($paramArray);
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,第一个版本的代码更简单; 但是第二个版本确实执行批量插入.批量插入应该更快,但我同意@BillKarwin认为在绝大多数实现中都不会注意到性能差异.
我会以第一种方式执行此操作,使用一行参数占位符准备语句,并使用execute一次插入一行.
$stmt = $db->prepare($sql);
foreach($rows as $row){
$stmt-> execute($row);
}
Run Code Online (Sandbox Code Playgroud)
它不如单个插入中的多行快,但它足够接近你可能永远不会注意到差异.
这样做的好处是可以很容易地使用代码.这就是为什么你要使用PHP,因为开发人员的效率,而不是运行时效率.
如果您有许多行(数百或数千),并且性能是优先考虑的事项,则应考虑使用LOAD DATA INFILE.