Menyelesaikan masalah SELECT FOR UPDATE dalam SQL Server
Isu ini terutamanya berpunca daripada ketidakserasian sintaks SELECT FOR UPDATE gaya Oracle dengan SQL Server . Walaupun SQL Server menyokong penguncian peringkat baris melalui mekanisme seperti updlock dan rowlock, ia tidak mempunyai persamaan langsung dengan SELECT FOR UPDATE.
Penyelesaian yang disediakan cuba untuk mencapai tingkah laku yang diingini dengan menggunakan petunjuk penguncian yang berbeza (updlock, xlock, dsb.) bersama-sama dengan tetapan dan teknik lain (DBCC TRACEON, READPAST). Walau bagaimanapun, seperti yang diakui oleh pengarang, tiada satu pun daripada pendekatan ini meniru sepenuhnya gelagat SELECT FOR UPDATE Oracle.
Dalam SQL Server, penguncian baris biasanya digunakan berdasarkan keadaan klausa WHERE khusus yang digunakan dalam pertanyaan. Ini bermakna penguncian akan berlaku hanya pada baris yang memenuhi kriteria yang ditentukan dalam pertanyaan. Oleh itu, adalah tidak mungkin untuk menghalang sambungan lain daripada mengakses atau mengubah suai baris yang berbeza dalam jadual yang sama, walaupun semasa menggunakan petunjuk penguncian.
Penyelesaian muktamad pengarang melibatkan menangkap jalan buntu dan pengecualian serentak untuk mengurangkan isu berkaitan penguncian yang berlebihan . Selain itu, mereka melaksanakan pengasingan syot kilat, yang membantu mengasingkan transaksi antara satu sama lain tetapi mempunyai had tertentu dan memerlukan konfigurasi pelayan pangkalan data.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Meniru Fungsi SELECT FOR UPDATE Oracle dalam SQL Server?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!