自认为已经了解Oracle左连接的用法,结果真正使用时发现完全不能按照应有的形式展现出来,就这么一个语句耗费了大半个小时才成功完成,并且不确认为什么会产生这样的结果,特写下过程,一防自己再次犯错,二也希望有人能够帮我深入了解问题的原因。
表一:ms_part,零件主表,主要涉及字段:零件号PART_NO和计划号PLAN_NO
AAA XXXX
BBB XXXX
CCC XXXX
DDD XXXX
EEE XXXX
AAAA FDFDF (只是说明还有其它计划号的AAA的零件)
BBB IERNE
表二:inv_mat,冲抵表,主要涉及字段:零件号PART_NO,冲抵数量INV_NUM,单据号BILL_CODE(和计划号无关系)
AAA 10 YYYY
CCC 5 YYYY
BBB 1 FIDFD (只是说明还有其它单据号的冲抵零件存在)
错误的语句:
SELECT MS_PART.PART_NO, INV_MAT.INV_NUM FROM MS_PART,INV_MAT WHERE MS_PART.PLAN_NO='xxxx'
AND INV_MAT.BILL_CODE='yyyyyy' AND MS_PART.PART_NO=INV_MAT.PART_NO(+)
希望得出形式如下:
零件号,冲抵数量
AAA 10
BBB
CCC 5
DDD
EEE
结果得出形式如下:
AAAA 10
CCC 5
抓狂了,不停的测试,+号放左边也试了,放右边也试了,就是得不出想要的结果,隐约感觉和两个表的条件有关系。
后将INV_MAT表的条件放在里面终于成功,但始终不明白为什么。
成功的语句:
SELECT MS_PART.PART_NO, I.INV_NUM FROM MS_PART, (SELECT * FROM INV_MAT WHERE BILL_CODE='yyyyyy') I WHERE MS_PART.PLAN_NO='xxxx' AND AND MS_PART.PART_NO=I.PART_NO(+)
等待高手.....
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/352988/viewspace-660235/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/352988/viewspace-660235/