当前位置:网站首页>MySql如何删除所有多余的重复数据
MySql如何删除所有多余的重复数据
2022-06-26 04:48:00 【唯空城】
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 t1
WHERE 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
)
- 最后删除成功之后,显示数据已经没有重复的了
边栏推荐
- 1.12 learning summary
- How to use the configured slave data source for the scheduled task configuration class scheduleconfig
- numpy 数据输入输出
- 2022.2.10
- 为什么许多shopify独立站卖家都在用聊天机器人?一分钟读懂行业秘密!
- Multipass Chinese document - use instance command alias
- 0622 horse palm fell 9%
- 做软件测试学历重要还是能力重要
- 1.16 learning summary
- A ZABBIX self discovery script (shell Basics)
猜你喜欢

SixTool-多功能多合一代挂助手源码

Wechat applet exits the applet (navigator and api--wx.exitminiprogram)
![Tp6 is easy to tread [original]](/img/e9/4b2fbd485387c5ed9e75bd0451a19c.jpg)
Tp6 is easy to tread [original]

Sixtool- source code of multi-functional and all in one generation hanging assistant

Multipass Chinese document - setup driver

2022 talent strategic transformation under the development trend of digital economy

1.19 learning summary

PIP batch complete uninstall package
![Simple personal summary of tp6 multi application deployment -- Part I [original]](/img/7b/65fab1973423081483dacc9bed9594.jpg)
Simple personal summary of tp6 multi application deployment -- Part I [original]

图像翻译/GAN:Unsupervised Image-to-Image Translation with Self-Attention Networks基于自我注意网络的无监督图像到图像的翻译
随机推荐
2021-01-31
PSIM software learning ---08 call of C program block
NVM installation and use and NPM package installation failure record
Guide de la pompe de données Oracle
"Eight hundred"
Zhimeng CMS will file a lawsuit against infringing websites
mysql高级学习(跟着尚硅谷老师周阳学习)
Large numbers (C language)
#微信小程序# 在小程序里面退出退出小程序(navigator以及API--wx.exitMiniProgram)
Method of saving pictures in wechat applet
2022.2.15
Thinkphp6 using kindeditor
Fastadmin always prompts sqlstate[23000]: integrity constraint violation: 1052 column 'ID' in order clause is am
Tips for using idea
Modify the number of Oracle connections
条件查询
Multipass Chinese document - use instance command alias
[H5 development] 02 take you to develop H5 list page ~ including query, reset and submission functions
[H5 development] 01 take you to experience H5 development from a simple page ~ the whole page implementation process from static page to interface adjustment manual teaching
Numpy random number