sql >> Database teknologi >  >> RDS >> Mysql

PHP udarbejdede erklæringer og transaktioner i en løkke

Din sløjfe kan optimeres ved at trække i prepare og bind_param udsagn ude af løkken.

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

Du har slået autocommit fra med din autocommit(FALSE) linje og behøver derfor ikke bruge START TRANSACTION erklæring.




  1. Xampp MS SQL server PHP 5.6

  2. MariaDB JSON_REMOVE() Forklaret

  3. Sådan annoteres MYSQL autoincrement-felt med JPA-annoteringer

  4. Kan ikke hente projektets metadata. Sørg for, at det er et MSBuild-baseret .NET Core-projekt