Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Pra-Kemas Kini dalam SQL Tanpa Pencetus atau Prosedur Tersimpan?

Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Pra-Kemas Kini dalam SQL Tanpa Pencetus atau Prosedur Tersimpan?

Linda Hamilton
Lepaskan: 2025-01-04 07:33:34
asal
765 orang telah melayarinya

How Can I Retrieve Pre-Update Column Values in SQL Without Triggers or Stored Procedures?

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;
Salin selepas log masuk

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;
Salin selepas log masuk

Pertimbangan Lain

  • Lajur yang digunakan untuk sambung sendiri mestilah unik dan bukan batal.
  • Adalah penting untuk menangkap dengan tepat keperluan kesesuaian aplikasi.
  • Menggunakan tahap pengasingan SERIALIZABLE boleh memastikan kemas kini serentak yang boleh dipercayai dengan mengorbankan prestasi.
  • Sebagai alternatif, penguncian eksplisit menggunakan UNTUK KEMASKINI boleh menyediakan keseimbangan antara kebolehpercayaan dan prestasi.

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!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan