Mendapatkan semula Nilai Lajur Pra-Kemas Kini Hanya Menggunakan SQL
Mendapatkan semula nilai asal lajur berturut-turut selepas kemas kini tanpa menggunakan pencetus, disimpan prosedur, atau entiti luaran lain ialah cabaran berulang dalam SQL. Untuk menangani perkara ini, kami meneroka pendekatan yang berbeza.
Percubaan dan Kelemahan Awal
Seperti yang dinyatakan dalam soalan asal, menggunakan UNTUK KEMASKINI dengan subquery mengandungi klausa KUMPULAN OLEH tidak boleh dilaksanakan. Akibatnya, cantuman menjadi tidak dapat dilaksanakan.
Penyelesaian Menggunakan Alias Jadual
Penyelesaian yang paling mudah ialah dengan menggabungkan jadual dengan dirinya sendiri menggunakan alias jadual. Dengan mengaliaskan jadual, kami boleh mengakses kedua-dua nilai asal dan yang dikemas kini. Pertimbangkan pertanyaan kemas kini berikut:
UPDATE my_table x SET processing_by = our_id_info FROM my_table y WHERE x.trans_nbr = y.trans_nbr AND x.row_id = y.row_id RETURNING y.processing_by AS old_processing_by, x.processing_by;
Mengendalikan Operasi Tulis Serentak
Untuk mengelakkan operasi tulis serentak daripada menjejaskan keputusan, kami boleh menggunakan UNTUK KEMASKINI klausa dalam subkueri. Ini memastikan bahawa hanya baris yang dikunci oleh subkueri diproses.
UPDATE tbl x SET tbl_id = 24, name = 'New Gal' FROM (SELECT tbl_id, name FROM tbl WHERE tbl_id = 4 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;
Pertimbangan Lain
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Pra-Kemas Kini dalam SQL Tanpa Pencetus atau Prosedur Tersimpan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!