Rumah > pangkalan data > Oracle > Bagaimana untuk memadam rekod pendua dalam oracle

Bagaimana untuk memadam rekod pendua dalam oracle

PHPz
Lepaskan: 2023-04-04 10:00:03
asal
7997 orang telah melayarinya

Dalam pangkalan data Oracle, disebabkan kerumitan dan perubahan berterusan data, rekod pendua sering berlaku, yang menyebabkan ralat sistem dan menjejaskan integriti dan ketepatan data. Oleh itu, adalah penting untuk mengalih keluar rekod pendua dalam pangkalan data Oracle.

Berikut ialah beberapa kaedah berkesan yang boleh membantu anda memadamkan rekod pendua dengan cepat.

1. Gunakan kata kunci DISTINCT

Kaedah 1: Gunakan kata kunci "DISTINCT" untuk memadam rekod pendua dengan pantas Anda boleh menggunakan pernyataan SQL berikut:

DELETE FROM table_name
WHERE rowid NOT IN (SELECT MIN(rowid) FROM table_name GROUP BY column1, column2, ..., column_n);
Salin selepas log masuk

Dalam pernyataan SQL ini, kata kunci "DISTINCT" menggabungkan lajur menjadi set yang ringkas untuk mencari rekod pendua. Penyata SELECT dan GROUP BY digunakan untuk mencari rekod pendua dan memadamkannya untuk memastikan ketepatan data.

Nota: Untuk satu lajur, anda boleh menggunakan kod SQL berikut:

DELETE FROM table_name
WHERE rowid NOT IN (SELECT MIN(rowid) FROM table_name GROUP BY column_name);
Salin selepas log masuk

2 Gunakan fungsi ROW_NUMBER()

Kaedah 2: ROW_NUMBER(. ) fungsi boleh menggunakan Teknologi pembahagian untuk mengenal pasti rekod pendua dan memadamnya:

DELETE FROM table_name
WHERE rowid IN (
  SELECT row_id FROM (
    SELECT rowid row_id,
    ROW_NUMBER() OVER (PARTITION BY column2, column3 ORDER BY column1) duplicate_records_count
    FROM table_name
  ) WHERE duplicate_records_count > 1
);
Salin selepas log masuk

Dalam pernyataan SQL ini, fungsi "ROW_NUMBER()" digunakan untuk mengenal pasti rekod pendua dan menandakan rekod pendua pertama sebagai "1 ", untuk membantu mengalih keluar rekod bertanda pendua lain. Membahagikan teknologi mengumpulkan rekod yang sama dan menyusunnya berdasarkan kumpulan untuk memastikan ketepatan data.

3. Gunakan subquery EXISTS

Kaedah 3: subquery EXISTS boleh menggunakan klausa WHERE untuk memadam rekod pendua:

DELETE table_name a
WHERE EXISTS (
  SELECT 1 FROM table_name b
  WHERE b.column1 = a.column1 AND b.column2 = a.column2 AND b.column3 = a.column3 AND b.rowid > a.rowid
);
Salin selepas log masuk

Dalam pernyataan SQL ini, subquery " EXISTS" mencari rekod dengan nilai yang sama dalam baris semasa (iaitu "a"). Oleh kerana ia adalah rekod pendua, ROWID mereka adalah berbeza. Oleh itu, selagi ROWID a lebih besar daripada ROWID b, rekod pendua boleh dipadamkan.

4. Gunakan operator set

Kaedah 4: Operator set boleh digabungkan dengan operator "SELECT" dan "UNION ALL" untuk mencari dan memadam rekod pendua.

DELETE FROM table_name
WHERE ROWID IN (
  SELECT ROWID FROM (
    SELECT column1, column2, column3, COUNT(*) duplicates
    FROM table_name
    GROUP BY column1, column2, column3
    HAVING COUNT(*) > 1
    UNION ALL
    SELECT column1, column2, column3, COUNT(*) duplicates
    FROM table_name
    GROUP BY column1, column2, column3
    HAVING COUNT(*) = 1
  ) a
  WHERE a.duplicates > 1
)
Salin selepas log masuk

Dalam pernyataan SQL ini, pengendali "UNION ALL" menggabungkan dua pernyataan SELECT untuk mencari rekod pendua dan rekod bukan pendua. Klausa HAVING digunakan untuk menapis rekod dengan kiraan pendua dan memadamkannya.

Ringkasnya, kaedah dan teknik yang berbeza boleh digunakan untuk mengalih keluar rekod pendua dalam pangkalan data Oracle. Hanya dengan mudah memilih kaedah yang sesuai berdasarkan keperluan anda. Semasa memadamkan rekod pendua, beri perhatian untuk melindungi integriti dan ketepatan data sistem.

Atas ialah kandungan terperinci Bagaimana untuk memadam rekod pendua dalam 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan