Mysql
 sql >> Datenbank >  >> RDS >> Mysql

PHP bereitete Anweisungen und Transaktionen in einer Schleife vor

Ihre Schleife kann durch Ziehen des prepare optimiert werden und bind_param Anweisungen aus der Schleife.

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

Sie haben Autocommit mit Ihrem autocommit(FALSE) deaktiviert Zeile und müssen daher nicht die START TRANSACTION verwenden Aussage.