oracle查询重复数据方法

oracle查询重复数据方法,第1张

比方说

在A表中存在一个字段 “name” ,

而且不同记录之间的 “name” 值有可能会相同,

现在就是需要查询出在该表中的各记录之间, “name” 值存在重复的项;

如果还查性别也相同大则如下:

有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重

复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。

就可以得到无重复记录的结果集。

如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除

发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。

假设有重复的字段为 Name , Address ,要求得到这两个字段唯一的结果集

最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写

在select子句中省去此列)

如果你只要id重复的,是\x0d\x0aselect * from 表 where id in (select id from 表 group by id having count(*)>1) \x0d\x0a \x0d\x0a如果你要所有字段都完全一样的重复记录的话,就是\x0d\x0aselect * from 表 where id in (select id from 表 group by id,name,age having count(*)>1)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6797074.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存