Rumah >pangkalan data >tutorial mysql >Bolehkah Transaksi MySQL dengan PDO Berjalan Serentak Tanpa Gangguan?
Topik transaksi pangkalan data selalunya disertakan dengan akronim ACID, mewakili Atomicity, Consistency, Isolation dan Durability. Dalam istilah yang lebih mudah, urus niaga memastikan operasi pangkalan data dilakukan dengan pasti dan tidak terjejas oleh sambungan serentak yang lain.
Walau bagaimanapun, satu persoalan timbul: bolehkah berbilang skrip PHP menjalankan transaksi serentak tanpa gangguan? Untuk memahami perkara ini, pertimbangkan senario berikut:
Anggapkan jadual bernama "pekerja" dengan dua medan: "id" dan "gaji." Dua skrip, script1.php dan script2.php, laksanakan kod berikut serentak:
<code class="php">$conn->beginTransaction(); $stmt = $conn->prepare("SELECT * FROM employees WHERE name = ?"); $stmt->execute(['ana']); $row = $stmt->fetch(PDO::FETCH_ASSOC); $salary = $row['salary']; $salary = $salary + 1000; $stmt = $conn->prepare("UPDATE employees SET salary = {$salary} WHERE name = ?"); $stmt->execute(['ana']); $conn->commit();</code>
Apakah yang akan menjadi gaji yang terhasil untuk "ana" dalam senario ini?
Jawapannya bergantung pada tahap pengasingan yang dikonfigurasikan untuk enjin jadual MySQL InnoDB. InnoDB menyokong empat tahap pengasingan, seperti yang ditentukan oleh standard SQL:
Secara lalai, MySQL menggunakan tahap pengasingan "Read Committed". Dalam tahap ini, hasilnya akan menjadi 11000. Ini kerana script1.php dan script2.php membaca data yang sama sebelum salah satu daripada mereka melakukan.
Jika tahap pengasingan "Boleh Bersiri" digunakan, hasilnya akan menjadi 12000. Ini kerana Serializable memastikan transaksi dilaksanakan secara berurutan dan menghalang transaksi lain daripada mengganggu data yang dikunci.
Dalam contoh yang diberikan, urutan peristiwa ialah:
Dengan pengasingan "Read Committed", kedua-dua skrip membaca data yang sama sebelum mana-mana daripadanya melakukan. Oleh itu, kenaikan gaji tidak diasingkan dan digunakan dua kali, menyebabkan kenaikan sebanyak 2000.
Dengan pengasingan "Serializable", transaksi pertama (script1.php) mengunci baris untuk "ana" apabila ia memilih data. Apabila script2.php cuba memilih data yang sama, ia akan menunggu sehingga transaksi pertama dilakukan. Ini memastikan bahawa data tidak diubah suai oleh transaksi lain semasa ia dibaca, dan kenaikan gaji hanya digunakan sekali, menyebabkan peningkatan sebanyak 1000.
Oleh itu, gangguan antara transaksi serentak bergantung kepada tahap pengasingan dan urutan operasi tertentu. Memahami implikasi tahap pengasingan yang berbeza adalah penting untuk memastikan urus niaga berkelakuan seperti yang dimaksudkan dalam persekitaran serentak.
Atas ialah kandungan terperinci Bolehkah Transaksi MySQL dengan PDO Berjalan Serentak Tanpa Gangguan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!