Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Meniru Fungsi RowID Oracle dalam MySQL?

Bagaimanakah Saya Boleh Meniru Fungsi RowID Oracle dalam MySQL?

Linda Hamilton
Lepaskan: 2024-11-29 15:33:10
asal
169 orang telah melayarinya

How Can I Replicate Oracle's RowID Functionality in MySQL?

MySQL Equivalent to Oracle's RowID

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.

Pendekatan Alternatif untuk Pembuangan Duplikasi Data

Untuk mengalih keluar nilai pendua dan mengenakan kunci utama seperti dalam kes rowid Oracle, anda boleh ikut langkah ini:

  1. Gunakan Sesi Pembolehubah:

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

    Ini menjana pengecam unik seperti rowid untuk setiap baris.

  2. Buat Jadual Sementara:

    CREATE TEMPORARY TABLE duplicates ...
    Salin selepas log masuk
  3. 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;
    Salin selepas log masuk
  4. 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
    Salin selepas log masuk

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!

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