Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mensimulasikan Fungsi ROWID Oracle dalam MySQL?

Bagaimana untuk Mensimulasikan Fungsi ROWID Oracle dalam MySQL?

Linda Hamilton
Lepaskan: 2024-12-01 00:24:19
asal
271 orang telah melayarinya

How to Simulate Oracle's ROWID Functionality in MySQL?

MySQL Equivalent of Oracle's RowID

Dalam MySQL, tiada setara langsung dengan rowid Oracle. Walau bagaimanapun, adalah mungkin untuk mencapai kefungsian yang serupa menggunakan pembolehubah sesi dan subquery.

Untuk memadamkan baris pendua dan menguatkuasakan kunci utama komposit, anda boleh menggunakan pendekatan berikut:

SELECT @rowid:=@rowid+1 as rowid
FROM my_table, (SELECT @rowid:=0) as init
ORDER BY field1, field2
Salin selepas log masuk

Pertanyaan ini akan tetapkan rowids pada jadual, tetapi ambil perhatian bahawa subqueries tidak boleh mengisih jadual yang anda cuba padamkan dari.

Untuk menangani had ini, cipta jadual sementara, masukkan subkueri julat ke dalamnya dan padam daripada jadual asal berdasarkan gabungan dengan jadual sementara menggunakan pengecam baris unik:

CREATE TEMPORARY TABLE duplicates ...

INSERT INTO duplicates (rowid, field1, field2, some_row_uid)
SELECT
  @rowid:=IF(@f1=field1 AND @f2=field2, @rowid+1, 0) as rowid,
  @f1:=field1 as field1,
  @f2:=field2 as field2,
  some_row_uid
FROM testruns t, (SELECT @rowid:=NULL, @f1:=NULL, @f2:=NULL) as init
ORDER BY field1, field2 DESC;

DELETE FROM my_table USING my_table JOIN duplicates
  ON my_table.some_row_uid = duplicates.some_row_uid AND duplicates.rowid > 0
Salin selepas log masuk

Kaedah ini sepatutnya berfungsi untuk operasi sekali anda tanpa overhed yang ketara.

Atas ialah kandungan terperinci Bagaimana untuk Mensimulasikan Fungsi ROWID Oracle dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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