Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Instruções e transações preparadas pelo PHP em um loop


Seu loop pode ser otimizado puxando o prepare e bind_param declarações fora do loop.
$value = null;
$mysqli->autocommit(FALSE);
$sql  = "INSERT INTO temp (`fund_id`) VALUES (?)";
$stmt = $mysqli->prepare($sql);
$stmt->bind_param('i', $value);
foreach ($pdata as $value) {
    $stmt->execute();
}
$mysqli->commit();

Você desativou o autocommit com seu autocommit(FALSE) linha e, portanto, não precisa usar o START TRANSACTION demonstração.