Oracle 如何查询相同的数据

一个表中,请注意是一张表中。有两条重复的,也有三条重复的,我怎么查询出相同的数据来,过滤掉单条的数据。比如idnameage001a18002b19001a18003c2... 一个表中,请注意是一张表中。有两条重复的,也有三条重复的,我怎么查询出相同的数据来,过滤掉单条的数据。比如

id name age
001 a 18
002 b 19
001 a 18
003 c 20

我只查出001的两条。而过滤掉002.003.SQL该怎么写
展开
 我来答
创作者gfdfsdfsw
推荐于2018-06-13 · 超过22用户采纳过TA的回答
知道答主
回答量:76
采纳率:0%
帮助的人:37万
展开全部
如果你只要id重复的,是
select * from 表 where id in (select id from 表 group by id having count(*)>1)

如果你要所有字段都完全一样的重复记录的话,就是
select * from 表 where id in (select id from 表 group by id,name,age having count(*)>1)
flyingFish211
推荐于2018-02-28 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
1)
select *
from tab t
where exists (select 1 from tab where id = t.id and (name <> t.name or age <> t.age)

2)
select *
from tab
where id in (select id from tab group by id having count(*) > 1)
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
不知名的药2
2012-08-04
知道答主
回答量:62
采纳率:0%
帮助的人:18.1万
展开全部
首先你说的重复是说id重复还是所有字段重复?select * from tablename group by id having count(*)>1。把id字段换成你认为是重复字段即可,如果是所有字段,则把所有字段写上去。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wuhu_314
2012-08-04 · TA获得超过273个赞
知道答主
回答量:88
采纳率:0%
帮助的人:26.4万
展开全部
像你给数的例子这样就可以了。
select distinct id,name,age from 表名 ;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式