电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

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

Mysql 刪除重復數據保留一條有效數據

一、Mysql 刪除重復數據,保留一條有效數據

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);

原理:

根據字段對數據進行分組,查詢出所有分組的最小ID(即要保留的不重復數據)將查詢出來的數據(所有不重復的數據)存放到臨時表中從原來的表中刪除ID不在臨時表中的重復數據

二、Mysql 刪除重復數據(多個字段分組)

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 查詢出可以刪除的重復數據

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);

補充:mysql刪除重復記錄并且只保留一條

準備的測試表結構及數據

插入的數據中A,B,E存在重復數據,C沒有重復記錄

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關鍵字篩選出表中重復數據

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

可以通過分組語句從每種重復數據中都拿出一條標識

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

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

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

執行后最終結果

方法二

MySql如何刪除所有多余的重復數據

方法一查詢出的所有多余的重復記錄:

方法二查詢出的所有多余的重復記錄(與方法一的結果相同):

方法三查詢出的所有多余的重復記錄:這里方法三因為用了MAX()方法(也可改用MIN()),查詢結果記錄的id不太一樣,但也可以被視為重復多余的數據,關鍵是你希望選擇保留哪一條記錄而已。

MySql如何刪除所有多余的重復數據 需要處理的數據,如:

出現重復的數據,如:

先用SELECT查詢看看結果:

-- 方法一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)

方法一查詢出的所有多余的重復記錄:

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

方法二查詢出的所有多余的重復記錄(與方法一的結果相同):

-- 方法三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)

方法三查詢出的所有多余的重復記錄:

這里方法三因為用了MAX()方法(也可改用MIN()),查詢結果記錄的id不太一樣,但也可以被視為重復多余的數據,關鍵是你希望選擇保留哪一條記錄而已。

下面是對上面的SELECT語句稍作修改并加入了DELETE

-- 方法一(笨方法但容易理解)DELETE FROM t_user WHERE user_name IN (	SELECT t1.user_name FROM (		-- 查詢出所有重復的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 (		-- 查詢出所有重復的記錄并各自只取其中一條(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 (		-- 過濾出重復多余的數據,比如,如果所有記錄中存在1條記錄是user_name=zhangsan的,那么就取出它;    	-- 如果所有記錄中存在多條記錄是user_name=lisi的,那么只取其中1條,其他的不查詢出來		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. 關于所有存在相同user_name的記錄,只查詢出(保留)重復記錄中的1條,假設這樣查詢出來的集合為A集合。		-- 2. 在所有記錄中,只要id不在A集合中的,都把它們查詢出來		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)

最后刪除成功之后,顯示數據已經沒有重復的了

到此這篇關于Mysql 刪除重復數據保留一條有效數據的文章就介紹到這了,更多相關Mysql 刪除重復數據內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MySQL
主站蜘蛛池模板: 苏州教学设备-化工教学设备-环境工程教学模型|同科教仪 | 科箭WMS仓库管理软件-TMS物流管理系统-科箭SaaS云服务 | 滤芯,过滤器,滤油机,贺德克滤芯,精密滤芯_新乡市宇清流体净化技术有限公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 代理记账_公司起名核名_公司注册_工商注册-睿婕实业有限公司 | 丹佛斯压力传感器,WISE温度传感器,WISE压力开关,丹佛斯温度开关-上海力笙工业设备有限公司 | 订做不锈钢_不锈钢定做加工厂_不锈钢非标定制-重庆侨峰金属加工厂 | 定坤静电科技静电消除器厂家-除静电设备 | 爆破器材运输车|烟花爆竹运输车|1-9类危险品厢式运输车|湖北江南专用特种汽车有限公司 | 免费个人pos机申请办理-移动pos机刷卡-聚合收款码办理 | BAUER减速机|ROSSI-MERSEN熔断器-APTECH调压阀-上海爱泽工业设备有限公司 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 精准猎取科技资讯,高效阅读科技新闻_科技猎 | 防火卷帘门价格-聊城一维工贸特级防火卷帘门厂家▲ | 收录网| 岩棉切条机厂家_玻璃棉裁条机_水泥基保温板设备-廊坊鹏恒机械 | 苏州西朗门业-欧盟CE|莱茵UL双认证的快速卷帘门品牌厂家 | 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 液压升降平台_剪叉式液压/导轨式升降机_传菜机定做「宁波日腾升降机厂家」 | 医养体检包_公卫随访箱_慢病随访包_家签随访包_随访一体机-济南易享医疗科技有限公司 | 报警器_家用防盗报警器_烟雾报警器_燃气报警器_防盗报警系统厂家-深圳市刻锐智能科技有限公司 | GAST/BRIWATEC/CINCINNATI/KARL-KLEIN/ZIEHL-ABEGG风机|亚喜科技 | 高压互感器,电流互感器,电压互感器-上海鄂互电气科技有限公司 | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 磁力抛光机_磁力研磨机_磁力去毛刺机_精密五金零件抛光设备厂家-冠古科技 | 视觉检测设备_自动化检测设备_CCD视觉检测机_外观缺陷检测-瑞智光电 | 捆扎机_气动捆扎机_钢带捆扎机-沈阳海鹞气动钢带捆扎机公司 | 济南办公室装修-厂房装修-商铺装修-工装公司-山东鲁工装饰设计 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 背压阀|减压器|不锈钢减压器|减压阀|卫生级背压阀|单向阀|背压阀厂家-上海沃原自控阀门有限公司 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 济南轻型钢结构/济南铁艺护栏/济南铁艺大门-济南燕翔铁艺制品有限公司 | 轻型地埋电缆故障测试仪,频响法绕组变形测试仪,静荷式卧式拉力试验机-扬州苏电 | 平面钻,法兰钻,三维钻-山东兴田阳光智能装备股份有限公司 | 吸音板,隔音板,吸音材料,吸音板价格,声学材料 - 佛山诺声吸音板厂家 | 网站优化公司_北京网站优化_抖音短视频代运营_抖音关键词seo优化排名-通则达网络 | 西装定制/做厂家/公司_西装订做/制价格/费用-北京圣达信西装 | 纸箱抗压机,拉力机,脂肪测定仪,定氮仪-山东德瑞克仪器有限公司 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 药品仓库用除湿机-变电站用防爆空调-油漆房用防爆空调-杭州特奥环保科技有限公司 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 |