Rumah > pangkalan data > tutorial mysql > Adakah MySQL Mempunyai Setara ROWID untuk Memadam Rekod Pendua?

Adakah MySQL Mempunyai Setara ROWID untuk Memadam Rekod Pendua?

Linda Hamilton
Lepaskan: 2024-12-09 20:20:15
asal
533 orang telah melayarinya

Does MySQL Have a ROWID Equivalent for Deleting Duplicate Records?

MySQL Equivalent of Oracle's RowID

Dalam Oracle, lajur ROWID secara unik mengenal pasti setiap baris dalam jadual. Adakah terdapat lajur yang setara dalam MySQL?

Persoalan sering timbul apabila menjalankan operasi seperti memadam rekod pendua semasa mengenakan kunci utama, seperti dalam pertanyaan yang disediakan:

delete from my_table where rowid not in (select max(rowid) from my_table group by field1,field2)
Salin selepas log masuk

Penyelesaian MySQL

Tidak seperti Oracle, MySQL tidak mempunyai persamaan langsung dengan ROWID. Sebaliknya, anda boleh menggunakan pembolehubah sesi untuk menjana pengecam baris unik:

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

Walau bagaimanapun, pendekatan ini tidak boleh digunakan dalam subkueri yang mengisih pada jadual sasaran yang dipadamkan.

Pendekatan Alternatif

Untuk memadamkan rekod pendua dan menguatkuasakan kunci utama, anda boleh membuat jadual sementara untuk menyimpan 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

Pendekatan ini mencipta jadual sementara, memasukkan pengecam baris unik dan kemudian menggunakan gabungan untuk memadamkan rekod pendua daripada jadual asal. Walaupun ia menambah overhed kecil, ia merupakan penyelesaian yang berdaya maju untuk operasi sekali sahaja.

Atas ialah kandungan terperinci Adakah MySQL Mempunyai Setara ROWID untuk Memadam Rekod Pendua?. 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