Mysql
 sql >> Base de données >  >> RDS >> Mysql

PHP a préparé des instructions et des transactions en boucle

Votre boucle peut être optimisée en tirant le prepare et bind_param déclarations hors de la boucle.

$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();

Vous avez désactivé la validation automatique avec votre autocommit(FALSE) ligne et n'ont donc pas besoin d'utiliser le START TRANSACTION déclaration.