Pemprosesan Transaksi Pelayan SQL: Ralat Tingkah Laku Balik
Pastikan anda mempertimbangkan gelagat transaksi pangkalan data anda apabila melaksanakan berbilang penyata SQL sebagai perintah kelompok tunggal. Khususnya, jika satu atau lebih penyata menghadapi ralat, adakah keseluruhan urus niaga perlu digulung semula?
Dalam Pelayan SQL, tingkah laku lalai adalah untuk melancarkan semula keseluruhan transaksi atas sebarang kegagalan. Walau bagaimanapun, dalam beberapa kes (seperti contoh yang diberikan dalam soalan):
<code class="language-sql">BEGIN TRAN; INSERT INTO myTable (myColumns ...) VALUES (myValues ...); INSERT INTO myTable (myColumns ...) VALUES (myValues ...); INSERT INTO myTable (myColumns ...) VALUES (myValues ...); COMMIT TRAN;</code>
Di mana pernyataan SQL dihantar sebagai perintah rentetan tunggal, tingkah laku rollback mungkin tidak seperti yang diharapkan.
Untuk memastikan penyata yang gagal mencetuskan pemulangan secara automatik, anda boleh menggunakan penyata SET XACT_ABORT ON
sebelum memulakan transaksi. Perintah ini mengubah suai tingkah laku urus niaga sesi supaya sebarang ralat yang dihadapi serta-merta menyebabkan urus niaga ditarik balik. Dalam kes ini, operasi sisipan akan dikembalikan dan transaksi tidak akan berjaya diselesaikan.
Dengan menetapkan XACT_ABORT ON
secara eksplisit, pangkalan data dijamin berfungsi secara konsisten apabila ralat berlaku, memastikan integriti data dan mencegah perubahan yang tidak disengajakan. Perlu diingat bahawa tetapan ini hanya digunakan pada sesi semasa dan tidak akan menjejaskan transaksi berikutnya.
Atas ialah kandungan terperinci Adakah SQL Server Memundurkan Keseluruhan Transaksi pada Ralat dalam Perintah Berkelompok?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!