Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Lama Semasa Operasi SQL UPDATE?

Bagaimanakah Saya Boleh Dapatkan Nilai Lajur Lama Semasa Operasi SQL UPDATE?

Mary-Kate Olsen
Lepaskan: 2025-01-04 09:42:35
asal
127 orang telah melayarinya

How Can I Retrieve Old Column Values During an SQL UPDATE Operation?

Mengambil Nilai Lajur Lama Semasa KEMASKINI Menggunakan SQL Tulen

Pengenalan

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.

Penyelesaian Menggunakan Join Sendiri

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

Pertanyaan ini melakukan langkah-langkah berikut:

  1. Menapis dan mengenal pasti baris untuk dikemas kini menggunakan subkueri.
  2. Menyertai jadual kepada dirinya sendiri menggunakan alias (old_my_table) untuk mengakses lajur asal nilai.
  3. Menetapkan processing_by kepada our_id_info dan bergabung hanya pada ID baris yang sepadan.
  4. Mengembalikan ID baris, nilai_proses_baru dan nilai_proses_lama.

Mengelakkan Isu Tulis Serentak

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:

Tahap Pengasingan Boleh Bersiri

Mensiri urus niaga dengan tahap pengasingan BERSERIALIZASI memastikan tiada transaksi lain boleh mengakses data semasa operasi. Walau bagaimanapun, ini boleh menjejaskan prestasi.

Penguncian Eksplisit

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

Kesimpulan

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!

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