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)?

Ответ 1

Ваш цикл можно оптимизировать, вытягивая выражения prepare и bind_param из цикла.

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

Вы отключили автосообщение со своей строкой autocommit(FALSE) и, следовательно, не нужно использовать оператор START TRANSACTION.