Классическом транзакции в коде цикла:PHP подготовленных операторов и операций в цикле
$mysqli->query("START TRANSACTION");
foreach ($pdata as $key => $value) {
$sql = "INSERT INTO temp (`fund_id`) VALUES (" . $value . ")";
$result = $mysqli->query($sql);
}
$mysqli->query("COMMIT");
Затем мы изменяем на заранее подготовленные заявления:
$mysqli->autocommit(FALSE);
foreach ($pdata as $key => $value) {
$sql = "INSERT INTO temp (`fund_id`) VALUES (?)";
$stmt = $mysqli->prepare($sql);
$stmt->bind_param('i', $value);
$stmt->execute();
}
$mysqli->commit();
Вопросы:
1) эти два кода идентичны? Я что-то пропустил во втором коде с подготовленными заявлениями?
2) Есть $mysqli->commit()
так же, как $mysqli->query("COMMIT")
?
3) Нужно ли добавить $mysqli->query("START TRANSACTION");
для блока подготовленных операторов, или транзакция автоматически запустится, когда мы установим autocommit(FALSE)
?
Вам не нужно «НАЧАТЬ СДЕЛКУ» после того, как вы отключили автокоммутацию. Вы можете '$ mysqli-> подготовить()' _before_ ваш цикл, а затем выполнить() внутри цикла foreach. Не нужно «готовить»() 'it на каждой итерации цикла. –
Вам также не нужно связывать 'bind_param()' каждый раз. Он связывает ссылку на переменную, поэтому каждый раз, когда вы ее выполняете, будет использоваться текущее значение переменной. – Barmar