Rumah > pangkalan data > tutorial mysql > Apakah Alternatif MySQL kepada RowID Oracle?

Apakah Alternatif MySQL kepada RowID Oracle?

Linda Hamilton
Lepaskan: 2024-12-05 00:34:11
asal
896 orang telah melayarinya

What are the MySQL Alternatives to Oracle's RowID?

MySQL Equivalent of Oracle's RowID

Dalam MySQL, tiada persamaan langsung dengan Oracle's RowID. Walau bagaimanapun, terdapat beberapa cara untuk mencapai kefungsian yang serupa.

Satu pendekatan ialah menggunakan pembolehubah sesi dan subkueri:

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

Ini akan memberikan pengecam unik kepada setiap baris, yang boleh digunakan untuk mengisih atau tujuan lain.

Satu lagi pendekatan untuk memadam rekod pendua adalah dengan mencipta jadual sementara dan melakukan cantuman antara jadual sementara dan jadual asal:

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 disyorkan apabila pengisihan tidak boleh dilakukan pada jadual yang dipadamkan daripada dalam subkueri.

Atas ialah kandungan terperinci Apakah Alternatif MySQL kepada RowID Oracle?. 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