在 sql 中刪除重復數據可通過以下方法:使用 distinct 關鍵字從查詢結果中移除重復值。使用 distinct 關鍵字與 delete 語句一起從表中刪除重復行。
SQL 中刪除重復數據
在 SQL 中刪除重復數據的主要方法是使用 DISTINCT 和 DELETE 語句。
DISTINCT
DISTINCT 關鍵字用于從查詢結果中移除重復值。它可以與 SELECT 語句一起使用,如下所示:
SELECT DISTINCT column_name1, column_name2 FROM table_name;
登錄后復制
這將返回一個查詢結果,其中 column_name1 和 column_name2 的組合是唯一的。
DELETE
DELETE 語句用于從表中刪除數據。要刪除重復數據,可以使用 DISTINCT 關鍵字與 DELETE 語句一起使用,如下所示:
DELETE FROM table_name WHERE (column_name1, column_name2) IN ( SELECT DISTINCT column_name1, column_name2 FROM table_name );
登錄后復制
這將刪除表中所有與 DISTINCT 查詢返回的結果匹配的重復行。
示例
假設有以下表:
create table my_table ( id int not null auto_increment primary key, name varchar(255) not null, email varchar(255) not null ); insert into my_table (name, email) values ('John Doe', 'john.doe@example.com'); insert into my_table (name, email) values ('John Doe', 'john.doe@example.com'); insert into my_table (name, email) values ('Jane Smith', 'jane.smith@example.com'); insert into my_table (name, email) values ('Jane Smith', 'jane.smith@example.com');
登錄后復制
要刪除表中重復的 name 和 email 組合:
DELETE FROM my_table WHERE (name, email) IN ( SELECT DISTINCT name, email FROM my_table );
登錄后復制
這將刪除兩個 John Doe 行,留下以下結果:
select * from my_table; | id | name | email | | --- | --- | --- | | 1 | John Doe | john.doe@example.com | | 3 | Jane Smith | jane.smith@example.com |
登錄后復制