sql >> Databasteknik >  >> RDS >> Mysql

PHP förberedde uttalanden och transaktioner i en loop

Din loop kan optimeras genom att dra prepare och bind_param uttalanden ur loopen.

$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 stängt av autocommit med din autocommit(FALSE) rad och behöver därför inte använda START TRANSACTION uttalande.




  1. Hur kan jag beskriva alla tabeller i databasen genom en sats?

  2. Summa över värden per månad i millisekunder

  3. SQL Server Passthrough-fråga som grund för en DAO-postuppsättning i Access

  4. MySQL SELECT unik kolumn där annan kolumn är max