成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何正確的使用一條SQL刪除重復數據

數據庫 SQL Server
數據庫中表存在重復數據,需要清理重復數據,清理后保留其中一條的情況是比較常見的需求,如何通過1條SQL準確的刪除數據呢?

數據庫中表存在重復數據,需要清理重復數據,清理后保留其中一條的情況是比較常見的需求,如何通過1條SQL準確的刪除數據呢?

1. 創建表及測試數據

1.1 數據庫中創建一張測試表

CREATE TABLE `test` (
`id` INT NOT NULL AUTO_INCREMENT,
`c1` VARCHAR(20) DEFAULT NULL,
`c2` VARCHAR(20) DEFAULT NULL,
`c3` INT DEFAULT NULL,
`c4` DATETIME DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

1.2 插入測試數據

INSERT INTO test(c1,c2,c3,c4) VALUES( 'a','b',10, '2022-05-24 18:00:46'),('a','c',20, '2022-05-24 18:00:46');
INSERT INTO test(c1,c2,c3,c4) VALUES( 'a','c',10, '2022-05-24 18:00:46'),('a','b',20, '2022-05-24 18:00:46');
INSERT INTO test(c1,c2,c3,c4) VALUES( 'b','c',10, '2022-05-24 18:00:46'),('d','b',20, '2022-05-24 18:00:46');
INSERT INTO test(c1,c2,c3,c4) VALUES( 'b','c',20, '2022-05-24 18:00:46'),('d','b',30, '2022-05-24 18:00:46');
INSERT INTO test(c1,c2,c3,c4) VALUES( 'b','c',20, '2022-05-24 18:00:46'),('a','b',40, '2022-05-24 18:00:46');
INSERT INTO test(c1,c2,c3,c4) VALUES( 'd','b',40, '2022-05-24 18:00:46'),('r','f',40, '2022-05-24 18:00:46');

1.3 查看重復數據

例如c1,c2 這2個字段組合作為唯一條件,則查詢重復數據的SQL如下

SELECT
c1,
c2,
COUNT(*)
FROM
test
GROUP BY c1,
c2
HAVING COUNT(*) > 1;

可見,結果如下:

2. 如何刪除重復數據

2.1 方案一

很多研發同學習慣的思路如下:

  • 先查出重復的記錄(使用in)
  • 再查出在重復記錄但id不在每組id最大值的記錄
  • 直接將select 改為delete進行刪除

查詢SQL如下

SELECT *    FROM  test  
WHERE (c1,c2) IN (
SELECT c1,c2
FROM test
GROUP BY c1,c2
HAVING COUNT(*)>1 )
AND id NOT IN (
SELECT MAX(id)
FROM test
GROUP BY c1,c2
HAVING COUNT(*)>1)
ORDER BY c1,c2
;

看上去比較符合結果了,但是改為delete執行的時候結果如下:

--  delete SQL
DELETE FROM test
WHERE (c1,c2) IN (
SELECT c1,c2
FROM test
GROUP BY c1,c2
HAVING COUNT(*)>1 )
AND id NOT IN (
SELECT MAX(id)
FROM test
GROUP BY c1,c2
HAVING COUNT(*)>1)

出現報錯信息:

錯誤代碼:1093
You can't specify target table 'test' for update in FROM clause

也就是說MySQL里需刪除的目標表在in子查詢中時,不能直接執行刪除操作。

3. 推薦寫法

基于以上情況,使用單條SQL刪除的方式如下:

查詢SQL:

SELECT  a.*  
FROM test a ,
(SELECT c1,c2,MAX(id)id FROM test GROUP BY c1,c2 HAVING COUNT(*)>1)b
WHERE a.c1=b.c1 AND a.c2=b.c2
AND a.id <>b.id

刪除SQL

DELETE  a 
FROM test a ,
(SELECT c1,c2,MAX(id)id FROM test GROUP BY c1,c2 HAVING COUNT(*)>1)b
WHERE a.c1=b.c1 AND a.c2=b.c2
AND a.id <>b.id

結果:

<n>查詢:delete a FROM test a , (select c1,c2,max(id)id from test group by c1,c2 having count(*)>1)b where a.c1=b.c1 and a.c2=b.c2 and a....


7 行受到影響

刪除后數據如下:

無重復數據了。

責任編輯:華軒 來源: 今日頭條
相關推薦

2023-01-03 07:44:53

MySQL查詢重復

2010-07-07 16:53:54

SQL Server重

2010-07-08 13:20:05

SQL Server刪

2021-11-30 10:00:01

SQL數據重復

2011-04-13 13:13:09

重復數據刪除

2010-07-26 09:55:55

SQL Server重

2010-07-08 13:06:05

SQL Server刪

2010-07-21 11:38:59

SQL Server重

2010-07-26 14:58:26

SQL Server刪

2025-05-20 00:00:00

2010-07-01 12:29:27

SQL Server重

2010-07-23 16:21:37

SQL Server重

2010-07-23 15:09:42

SQL Server刪

2011-04-13 13:05:14

重復數據刪除

2024-10-16 17:04:13

2025-05-12 08:27:25

2009-01-11 17:32:03

Oracle數據庫重復數據

2010-09-02 10:36:51

SQL刪除

2020-05-26 09:08:23

命令循環Linux

2011-08-04 12:49:31

SQL Server數重復數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区三区四区 | 亚洲成av人片在线观看无码 | 亚洲精品免费在线观看 | 国产日韩精品一区二区三区 | 国产精品久久久久久久久久 | 欧美中文字幕一区二区三区亚洲 | 欧美www在线观看 | 中文字幕日本一区二区 | 欧美a区| 国产日韩精品在线 | 99成人在线视频 | 宅男伊人| 狠狠做深爱婷婷综合一区 | 天天操天天摸天天干 | 午夜国产 | 91麻豆精品国产91久久久更新资源速度超快 | 中文字幕电影在线观看 | 亚洲国产成人精品久久久国产成人一区 | 亚洲在线免费 | 免费一区在线 | 91国在线观看 | 99精品免费久久久久久日本 | 91高清视频在线观看 | 久久亚洲精品久久国产一区二区 | 日韩欧美亚洲 | 久久一二区| 国产精品视频久久 | 国产亚洲一区二区精品 | 日韩在线 | 欧美激情综合 | 久久精品亚洲一区二区三区浴池 | 国产欧美精品区一区二区三区 | 国产色播av在线 | 日韩欧美在线观看 | 男人的天堂在线视频 | 麻豆国产精品777777在线 | 在线观看成人小视频 | 精品国产欧美一区二区三区不卡 | 毛片99| 白浆在线 | 国产精品成人在线播放 |