Bagaimana untuk memadam rekod pendua dalam mysql

PHPz
Lepaskan: 2023-04-19 17:22:51
asal
809 orang telah melayarinya

MySQL ialah sistem pengurusan pangkalan data hubungan popular yang membolehkan pengguna menyimpan, mengurus dan mendapatkan semula data Ia adalah sistem klien/pelayan yang menggunakan bahasa SQL untuk mengakses pangkalan data. Walau bagaimanapun, apabila menggunakan MySQL, anda mungkin menghadapi situasi memadam rekod pendua, yang merupakan masalah yang sangat biasa dalam aplikasi sebenar. Di bawah ini kami akan memperkenalkan cara memadam rekod pendua dalam MySQL.

  1. Gunakan kata kunci DISTINCT:

DISTINCT ialah kata kunci yang digunakan untuk memadamkan data pendua dalam pangkalan data dan boleh digunakan dalam pernyataan SELECT. Contohnya, kod berikut memilih data yang berbeza daripada jadual:

 SELECT DISTINCT column_name FROM table_name;
Salin selepas log masuk

Ini mengembalikan set rekod yang berbeza. Kita boleh menggunakan pernyataan ini untuk memadam rekod pendua dalam jadual. Pertama, kita perlu mencipta jadual baharu untuk menyimpan data tanpa rekod pendua. Berikut ialah coretan kod cara mengalih keluar rekod pendua menggunakan kata kunci DISTINCT:

CREATE TABLE new_table AS SELECT DISTINCT * FROM old_table;
Salin selepas log masuk

Menggunakan pernyataan ini, kita boleh mencipta jadual baharu dan memasukkan rekod yang berbeza ke dalam jadual baharu.

  1. Gunakan GROUP BY:

Pernyataan GROUP BY digunakan untuk mengumpulkan hasil yang ditetapkan oleh satu atau lebih lajur dan secara pilihan menggunakan fungsi agregat pada setiap kumpulan . Contohnya, kod berikut boleh memilih jumlah setiap lajur dalam jadual:

SELECT column_name, SUM(column_name) FROM table_name GROUP BY column_name;
Salin selepas log masuk

Pernyataan SELECT yang lebih kompleks boleh menggunakan berbilang lajur dan secara pilihan menggunakan berbilang fungsi agregat dalam setiap kumpulan. Pernyataan GROUP BY juga boleh digunakan untuk mengalih keluar data pendua. Berikut ialah coretan kod cara mengalih keluar rekod pendua menggunakan GROUP BY dalam MySQL:

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

Menggunakan pernyataan ini, kita boleh memilih jadual dan mengalih keluar semua rekod pendua.

  1. Gunakan indeks UNIK:

Indeks UNIK ialah kekangan yang memerlukan setiap nilai muncul sekali sahaja dalam jadual. Ini dicapai dengan membuat indeks pada jadual. MySQL melemparkan ralat apabila cuba memasukkan baris dengan nilai indeks unik yang sama. Kami boleh menggunakan ciri ini untuk mengalih keluar rekod pendua. Berikut ialah coretan kod cara mengalih keluar rekod pendua menggunakan indeks UNIK dalam MySQL:

ALTER IGNORE TABLE table_name ADD UNIQUE (column_name);
Salin selepas log masuk

Menggunakan pernyataan ini, kita boleh mencipta indeks unik dan mengabaikan rekod pendua apabila cuba memasukkannya.

Ringkasan

Dalam MySQL, memadamkan rekod pendua adalah tugas yang sangat biasa. Walaupun terdapat beberapa cara berbeza untuk menyelesaikan tugasan ini, menggunakan indeks DISTINCT, GROUP BY, dan UNIQUE adalah salah satu yang paling biasa. Mana-mana kaedah yang anda pilih, anda harus menguji dan menyandarkan pangkalan data anda dengan teliti untuk memastikan anda tidak memadamkan rekod atau data penting secara tidak sengaja.

Atas ialah kandungan terperinci Bagaimana untuk memadam rekod pendua 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!