oracle plsql语句,有三张表联合查询,A表有id,name,grade,B表有pid,class,C表有tid,group,

A表的id等于B表的pid,等于C表的tid,现在要selectid,name,grade,class,groupfromA,B,Cwhereidbetween10and... A表的id等于B表的pid,等于C表的tid,现在要select id,name,grade,class,group from A,B,C where id between 10 and 20,问sql语句该怎么写
要求结果中id不能有重复的。
我本来写的是 select id,name,grade,class,group from A,B,C where A.id between 10 and 20 and B.pid between 10 and 20 and C.tid between 10 and 20.有两个id满足,但每个记录都显示了4次,表中出现了共8条记录。该怎么做才能返回两条记录?
展开
 我来答
micro0369
2013-08-01 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:3999万
展开全部

你这个关键在于,

id在A表是否可能重复?           ---假设是不能重复的

pid在B表是否可能重复?         ---假设是能重复的,pid,class联合起来是不重复的

tid在C表是否可能重复?          ---假设是能重复的,tid,group联合起来是不重复的

select a.id,a.name,a.grade,bb.class,cc.group
from a,
(select pid,max(class) class from b group by pid) bb,
(select tid,max(group) group from c group by tid) cc
where a.id = bb.pid and a.id = cc.tid
  and A.id between 10 and 20
更多追问追答
追问
max(class)是起什么作用?
追答
如果有重复的数据,我每一个id 只返回一行。
KevinHpli
2013-08-01 · TA获得超过1421个赞
知道小有建树答主
回答量:751
采纳率:80%
帮助的人:925万
展开全部
select id,name,grade,class,group from A a,B b,C c where a.id between 10 and 20 and a.id = b.pid and a.id = c.tid;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
信春哥_不挂科_
2013-07-31 · 超过21用户采纳过TA的回答
知道答主
回答量:51
采纳率:0%
帮助的人:56.1万
展开全部
select distinct id,name,grade,class,group from A,B,C where id=pid and id=tid and id>=10 and id<=20
更多追问追答
追问
我本来写的也是是 select id,name,grade,class,group from A,B,C where A.id between 10 and 20 and B.pid between 10 and 20 and C.tid between 10 and 20.有两个id满足,但每个记录都显示了4次,表中出现了共8条记录。该怎么做才能返回两条记录?
追答
你没有通过id和pid,tid相等来筛选数据,3张表直接连接时做笛卡尔积的,本来就是有重复数据的,你可以select * from A,B,C看一下结果
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式