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
Linda Hamiltonasal
2024-11-29 15:33:10197semak imbas

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

    Ini menjana pengecam unik seperti rowid untuk setiap baris.

  2. Buat Jadual Sementara:

    CREATE TEMPORARY TABLE duplicates ...
  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;
  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

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!

Kenyataan:
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