Dalam MySQL, ciri rowid yang disediakan oleh Oracle tidak tersedia secara langsung. Walau bagaimanapun, terdapat pendekatan alternatif untuk mencapai kefungsian yang serupa untuk tugas manipulasi data.
Untuk mengalih keluar nilai pendua dan mengenakan kunci utama seperti dalam kes rowid Oracle, anda boleh ikut langkah ini:
Gunakan Sesi Pembolehubah:
SELECT @rowid:=@rowid+1 as rowid FROM table1, (SELECT @rowid:=0) as init ORDER BY sorter_field
Ini menjana pengecam unik seperti rowid untuk setiap baris.
Buat Jadual Sementara:
CREATE TEMPORARY TABLE duplicates ...
Sisipkan Sarikata Bermula ke dalam Jadual Sementara:
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;
Padam Pendua:
DELETE FROM my_table USING my_table JOIN duplicates ON my_table.some_row_uid = duplicates.some_row_uid AND duplicates.rowid > 0
Pendekatan ini menyediakan penyelesaian untuk kekurangan setara rowid langsung dalam MySQL, membolehkan anda melaksanakan tugas manipulasi data pada jadual tanpa utama kunci.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Meniru Fungsi RowID Oracle dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!