发布网友 发布时间:2022-04-23 22:57
共3个回答
懂视网 时间:2022-04-30 10:18
delete from co_jobinformation c之前在oracle数据库中能删除重复数据并且能保留一条唯一数据,但是相同的MySQL中就不行,
mysql有个特性,对于表进行修改,删除操作,子查询不能和外层的查询的表一样,所以在加个select就可以了
DELETE tt.*
FROM t_user tt --这是操作的表
WHERE tt.username --这是用户名重复的数据
IN(
SELECT cc.username
FROM (
SELECT b.*
FROM t_user b
) cc
GROUP BY cc.username
HAVING COUNT(cc.username) >1
)
AND tt.id --这里是保留id最小的一条,应该比较容易看懂.
NOT IN(
SELECT MIN(e.id)
FROM(
SELECT ee.*
FROM t_user ee) e
GROUP BY e.username
HAVING COUNT(e.username )>1)
)
)
我写的有点丑,但是我想要的结果实现了,就是把上面子查询里面的表换成select查询,还请高手留下优质SQL,感激不尽!
MYSQL删除重复数据
标签:
热心网友 时间:2022-04-30 07:26
有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据。
本章节我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据。
删除重复数据
如果你想删除数据表中的重复数据,你可以使用以下的SQL语句:
当然你也可以在数据表中添加 INDEX(索引) 和 PRIMAY KEY(主键)这种简单的方法来删除表中的重复记录。方法如下:
热心网友 时间:2022-04-30 08:44
//去除重复的数据 如果是重复的只显示1个
select distinct d_name from tbl_vod
--下面是查出重复的记录
select d_name from tbl_vod
minus
select distinct d_name from tbl_vod