Vic*_*tor 9 sql outer-join oracle11g
如果我写一个sql:
select *
from a,b
where a.id=b.id(+)
and b.val="test"
Run Code Online (Sandbox Code Playgroud)
并且我希望b中相应记录所在的所有记录都不存在或者存在val ="test",这是正确的查询吗?
Jus*_*ave 17
使用ANSI语法会好得多
SELECT *
FROM a
LEFT OUTER JOIN b ON( a.id = b.id and
b.val = 'test' )
Run Code Online (Sandbox Code Playgroud)
您也可以使用Oracle的语法执行相同的操作,但它有点紧张
SELECT *
FROM a,
b
WHERE a.id = b.id(+)
AND b.val(+) = 'test'
Run Code Online (Sandbox Code Playgroud)
请注意,在这两种情况下,我都忽略了c表,因为您没有指定连接条件.而且我假设你真的不想加入A到B然后用C生成笛卡尔积.
| 归档时间: |
|
| 查看次数: |
43648 次 |
| 最近记录: |