2013-10-01 3 views
12

Классическом транзакции в коде цикла: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)?

+4

Вам не нужно «НАЧАТЬ СДЕЛКУ» после того, как вы отключили автокоммутацию. Вы можете '$ mysqli-> подготовить()' _before_ ваш цикл, а затем выполнить() внутри цикла foreach. Не нужно «готовить»() 'it на каждой итерации цикла. –

+5

Вам также не нужно связывать 'bind_param()' каждый раз. Он связывает ссылку на переменную, поэтому каждый раз, когда вы ее выполняете, будет использоваться текущее значение переменной. – Barmar

ответ

22

Ваша петля может быть оптимизирована путем вытягивания выводов 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 с autocommit(FALSE) линии и, следовательно, не нужно использовать START TRANSACTION заявление.

+0

короткие и соответствующие. – neophyte

Смежные вопросы