Apabila mengemas kini baris dalam pangkalan data, ia boleh berguna untuk mengakses yang asal nilai lajur yang dikemas kini. Walaupun SQL menawarkan klausa RETURNING untuk mendapatkan semula nilai pasca kemas kini, ia tidak menyokong pengambilan nilai lajur lama secara langsung. Artikel ini meneroka penyelesaian untuk mendapatkan kedua-dua nilai lajur baharu dan lama semasa operasi KEMASKINI.
Walaupun had klausa RETURNING, adalah mungkin untuk mengakses lajur asal nilai dengan menggabungkan jadual dengan dirinya sendiri. Teknik ini menghapuskan keperluan untuk pencetus atau prosedur tersimpan.
UPDATE my_table SET processing_by = our_id_info -- unique to this worker FROM my_table AS old_my_table WHERE trans_nbr IN ( SELECT trans_nbr FROM my_table GROUP BY trans_nbr HAVING COUNT(*) > 1 LIMIT our_limit_to_have_single_process_grab ) AND my_table.row_id = old_my_table.row_id RETURNING my_table.row_id, my_table.processing_by, old_my_table.processing_by AS old_processing_by;
Pertanyaan ini melakukan langkah-langkah berikut:
Sementara penyelesaian gabungan sendiri berfungsi dengan baik tanpa beban tulis serentak, ia memperkenalkan isu konkurensi jika berbilang pekerja cuba mengemas kini baris yang sama. Untuk menangani perkara ini:
Mensiri urus niaga dengan tahap pengasingan BERSERIALIZASI memastikan tiada transaksi lain boleh mengakses data semasa operasi. Walau bagaimanapun, ini boleh menjejaskan prestasi.
Mengunci baris khusus untuk dikemas kini menggunakan klausa UNTUK KEMASKINI menghalang transaksi lain daripada mengubah suai sehingga operasi selesai. Ini memastikan integriti data sambil mengekalkan prestasi.
UPDATE tbl x SET tbl_id = 23 , name = 'New Guy' FROM (SELECT tbl_id, name FROM tbl WHERE tbl_id = 3 FOR UPDATE) y WHERE x.tbl_id = y.tbl_id RETURNING y.tbl_id AS old_id, y.name AS old_name , x.tbl_id, x.name;
Dengan menggunakan gabungan sendiri dan menggunakan mekanisme kawalan konkurensi, adalah mungkin untuk mendapatkan kedua-dua nilai lajur lama dan baharu semasa KEMASKINI operasi menggunakan SQL tulen. Pendekatan ini memberikan fleksibiliti dan kawalan dalam mengendalikan pengubahsuaian data dalam sistem pangkalan data.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Lama Semasa Operasi SQL UPDATE?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!