色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Mysql 刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)(最新推薦)

瀏覽:124日期:2023-02-18 16:43:09
目錄
  • Mysql 刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)
    • 一、Mysql 刪除重復(fù)數(shù)據(jù),保留一條有效數(shù)據(jù)
    • 二、Mysql 刪除重復(fù)數(shù)據(jù)(多個(gè)字段分組)
    • 三、Mysql 查詢(xún)出可以刪除的重復(fù)數(shù)據(jù)
  • 補(bǔ)充:mysql刪除重復(fù)記錄并且只保留一條
    • MySql如何刪除所有多余的重復(fù)數(shù)據(jù) 需要處理的數(shù)據(jù),如:

Mysql 刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)

一、Mysql 刪除重復(fù)數(shù)據(jù),保留一條有效數(shù)據(jù)

DELETE FROM SZ_Building WHERE id NOT IN (  SELECT t.min_id FROM (    SELECT MIN(id) AS min_id FROM SZ_Building GROUP BY BLDG_NO  ) t);

原理:

根據(jù)字段對(duì)數(shù)據(jù)進(jìn)行分組,查詢(xún)出所有分組的最小ID(即要保留的不重復(fù)數(shù)據(jù))將查詢(xún)出來(lái)的數(shù)據(jù)(所有不重復(fù)的數(shù)據(jù))存放到臨時(shí)表中從原來(lái)的表中刪除ID不在臨時(shí)表中的重復(fù)數(shù)據(jù)

二、Mysql 刪除重復(fù)數(shù)據(jù)(多個(gè)字段分組)

DELETE FROM SZ_Water_Level WHERE id NOT IN (  SELECT t.min_id FROM (    SELECT MIN(id) AS min_id FROM SZ_Water_Level GROUP BY CZBM,SJ,SW  ) t);

三、Mysql 查詢(xún)出可以刪除的重復(fù)數(shù)據(jù)

SELECT * FROM SZ_Building WHERE BLDG_NO IN (	SELECT BLDG_NO FROM SZ_Building GROUP BY BLDG_NO HAVING COUNT(1)>1) AND id NOT IN (	SELECT MIN(id) FROM SZ_Building GROUP BY BLDG_NO HAVING COUNT(1)>1);

補(bǔ)充:mysql刪除重復(fù)記錄并且只保留一條

準(zhǔn)備的測(cè)試表結(jié)構(gòu)及數(shù)據(jù)

插入的數(shù)據(jù)中A,B,E存在重復(fù)數(shù)據(jù),C沒(méi)有重復(fù)記錄

CREATE TABLE `tab` (? `id` int(11) NOT NULL AUTO_INCREMENT,? `name` varchar(20) DEFAULT NULL,? PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8;?-- ------------------------------ Records of tab-- ----------------------------INSERT INTO `tab` VALUES ("1", "A");INSERT INTO `tab` VALUES ("2", "A");INSERT INTO `tab` VALUES ("3", "A");INSERT INTO `tab` VALUES ("4", "B");INSERT INTO `tab` VALUES ("5", "B");INSERT INTO `tab` VALUES ("6", "C");INSERT INTO `tab` VALUES ("7", "B");INSERT INTO `tab` VALUES ("8", "B");INSERT INTO `tab` VALUES ("9", "B");INSERT INTO `tab` VALUES ("10", "E");INSERT INTO `tab` VALUES ("11", "E");INSERT INTO `tab` VALUES ("12", "E");

使用HAVING關(guān)鍵字篩選出表中重復(fù)數(shù)據(jù)

SELECT `name`,COUNT(1) FROM TAB GROUP BY `name` HAVING COUNT(1) >1

可以通過(guò)分組語(yǔ)句從每種重復(fù)數(shù)據(jù)中都拿出一條標(biāo)識(shí)

SELECT `name`,id? FROM TAB GROUP BY `name`? HAVING COUNT(1) >1

刪除重復(fù)記錄并且只保留一條 [留意SQL注釋]

DELETE from tab where-- 刪除所有的重復(fù)時(shí)間 Begin --`name` in (?? ?SELECT * from (SELECT `name`FROM TAB GROUP BY `name`? HAVING COUNT(1) >1) tmp2)-- 刪除所有的重復(fù)時(shí)間 END ---- 但一些特定ID的記錄不進(jìn)行刪除? Begin --ANDid NOT in(?? ?select id from (?? ??? ?SELECT `name`,id? FROM TAB GROUP BY `name` HAVING COUNT(1) >1?? ?) tmp1)-- 但一些特定ID的記錄不進(jìn)行刪除? END --

執(zhí)行后最終結(jié)果

方法二

MySql如何刪除所有多余的重復(fù)數(shù)據(jù)

方法一查詢(xún)出的所有多余的重復(fù)記錄:

方法二查詢(xún)出的所有多余的重復(fù)記錄(與方法一的結(jié)果相同):

方法三查詢(xún)出的所有多余的重復(fù)記錄:這里方法三因?yàn)橛昧薓AX()方法(也可改用MIN()),查詢(xún)結(jié)果記錄的id不太一樣,但也可以被視為重復(fù)多余的數(shù)據(jù),關(guān)鍵是你希望選擇保留哪一條記錄而已。

MySql如何刪除所有多余的重復(fù)數(shù)據(jù) 需要處理的數(shù)據(jù),如:

出現(xiàn)重復(fù)的數(shù)據(jù),如:

先用SELECT查詢(xún)看看結(jié)果:

-- 方法一SELECT * FROM t_user WHERE user_name IN (?? ?SELECT user_name FROM t_user GROUP BY user_name HAVING COUNT(1)>1)?AND id NOT IN (?? ?SELECT MIN(id) FROM t_user GROUP BY user_name HAVING COUNT(1)>1)

方法一查詢(xún)出的所有多余的重復(fù)記錄:

-- 方法二SELECT * FROM t_user WHERE id NOT IN (	SELECT MIN(id) FROM t_user GROUP BY user_name)

方法二查詢(xún)出的所有多余的重復(fù)記錄(與方法一的結(jié)果相同):

-- 方法三SELECT * FROM t_user AS t1 WHERE t1.id <> (	SELECT MAX(t2.id) FROM t_user AS t2 WHERE t1.user_name=t2.user_name)

方法三查詢(xún)出的所有多余的重復(fù)記錄:

這里方法三因?yàn)橛昧薓AX()方法(也可改用MIN()),查詢(xún)結(jié)果記錄的id不太一樣,但也可以被視為重復(fù)多余的數(shù)據(jù),關(guān)鍵是你希望選擇保留哪一條記錄而已。

下面是對(duì)上面的SELECT語(yǔ)句稍作修改并加入了DELETE

-- 方法一(笨方法但容易理解)DELETE FROM t_user WHERE user_name IN (	SELECT t1.user_name FROM (		-- 查詢(xún)出所有重復(fù)的user_name		SELECT user_name FROM t_user GROUP BY user_name HAVING COUNT(1)>1	) t1) AND id NOT IN (	SELECT t2.min_id FROM (		-- 查詢(xún)出所有重復(fù)的記錄并各自只取其中一條(MIN(id)或MAX(id)都可以)		SELECT MIN(id) AS min_id FROM t_user GROUP BY user_name HAVING COUNT(1)>1	) t2)-- 方法二(推薦方法也容易理解)DELETE FROM t_user WHERE id NOT IN (	SELECT t.min_id FROM (		-- 過(guò)濾出重復(fù)多余的數(shù)據(jù),比如,如果所有記錄中存在1條記錄是user_name=zhangsan的,那么就取出它;    	-- 如果所有記錄中存在多條記錄是user_name=lisi的,那么只取其中1條,其他的不查詢(xún)出來(lái)		SELECT MIN(id) AS min_id FROM t_user GROUP BY user_name  ) t)-- 方法三(推薦方法但不太容易理解)DELETE FROM t_user WHERE id IN (	SELECT t.id FROM (		-- 1. 關(guān)于所有存在相同user_name的記錄,只查詢(xún)出(保留)重復(fù)記錄中的1條,假設(shè)這樣查詢(xún)出來(lái)的集合為A集合。		-- 2. 在所有記錄中,只要id不在A集合中的,都把它們查詢(xún)出來(lái)		SELECT t1.id FROM t_user AS t1 WHERE t1.id <> (SELECT MAX(t2.id) FROM t_user AS t2 WHERE t1.user_name=t2.user_name)	) t)-- 或DELETE FROM t_user t1WHERE t1.id <> (	SELECT t2.max_id FROM (		SELECT MAX(t3.id) AS max_id FROM t_user t3 WHERE t1.user_name=t3.user_name	) t2)

最后刪除成功之后,顯示數(shù)據(jù)已經(jīng)沒(méi)有重復(fù)的了

到此這篇關(guān)于Mysql 刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Mysql 刪除重復(fù)數(shù)據(jù)內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
主站蜘蛛池模板: 精品视频国产狼人视频 | 国产欧美久久精品 | 九九午夜 | 高清不卡日本v在线二区 | 久久久精品影院 | 国产男人天堂 | 日韩加勒比在线 | 国产成人亚洲综合91精品555 | 亚洲精品99久久久久久 | 国产一级精品视频 | cekc欧美| 视频一区在线播放 | 亚洲高清一区二区三区久久 | 美女啪啪网站又黄又免费 | 最近中文字幕在线 | 中文 | 国产激情视频在线 | 国产粉嫩高中生无套第一次 | 欧美一级做一级爱a做片性 欧美一欧美一级毛片 | 精品国产品香蕉在线观看 | 91香蕉成人免费高清网站 | 久草观看 | 成人精品视频在线观看播放 | 一 级 黄 色 片生活片 | 国产一级爱c片免费播放 | www.日本在线视频 | 日韩www视频 | 丁香久久 | 成年免费大片黄在线观看一 | 久久99视频精品 | 欧美国产永久免费看片 | 亚洲国产精品网 | 欧美成人自拍视频 | 成人黄色免费观看 | 一个人看的免费观看日本视频www | 欧美视频亚洲视频 | 国产精品特级毛片一区二区三区 | 久久视频免费在线观看 | 久久久久欧美精品观看 | 91久久国产精品视频 | 国产一区私人高清影院 | 视频偷拍一级视频在线观看 |