Oracle中左右连接外表带条件的写法

2012-11-12
  研究时测试用的例子:xtest2是基表,xtest1是外表表结构及数据如下
 
  xtest1(外表)
company_codeitem_codeitem_name cost_class
00item1name1f
00item2name2m
01item1name1m
01item2name2f
  xtest2(基表)
company_codeitem_codet1 t2
00item1aabb
00item2ccdd
00item3eeff
nullnullnullnull
  要求:将xtest2中的数据全部显出,根据xtest2中的公司号及物料代码去xtest1表里找对应的物料名,但是有一个附加条件,就是xtest1表里必须是cost_class='f'的才能写到最后的结果集中。最后实验成功的sql如下:
  select a.item_code,b.item_name from xtest2 a,xtest1 b where a.item_code = b.item_code(+) and b.cost_class(+)='f'and a.company_code = b.company_code(+)
  总结:b表的匹配条件还要加一个右连接,要不无法得到想要的结果。
  这个语句其实还有个问题,就是如果b表中符合条件的记录比a表多,考试大提示:那得到的结果集会有误,但是在要的程序结果不用考虑这种情况。http://ks.examda.com
分享到:
0
相关阅读
友情链接
© 2018 我考网 http://www.woexam.com 中国互联网举报中心 湘ICP备18023104号 京公网安备 11010802020116号
违法和不良信息举报:9447029@qq.com