sql – 如何使用带有过滤器where子句的oracle外连接
发布时间:2020-05-24 19:09:26 所属栏目:MsSql 来源:互联网
导读:如果我写一个SQL: select * from a,b where a.id=b.id(+) and b.val=test 并且我希望b中相应记录所在的所有记录都不存在或者存在val =“test”,这是正确的查询吗? 使用ANSI语法会好得多 SELECT * FROM a LEFT OUTER JOIN b ON( a.id = b.id an
|
如果我写一个SQL: select *
from a,b
where a.id=b.id(+)
and b.val="test"
并且我希望b中相应记录所在的所有记录都不存在或者存在val =“test”,这是正确的查询吗? 解决方法使用ANSI语法会好得多SELECT *
FROM a
LEFT OUTER JOIN b ON( a.id = b.id and
b.val = 'test' )
您也可以使用Oracle的语法执行相同的操作,但它有点紧张 SELECT * FROM a,b WHERE a.id = b.id(+) AND b.val(+) = 'test' 请注意,在这两种情况下,我都忽略了c表,因为您没有指定连接条件.而且我假设你真的不想加入A到B然后用C生成笛卡尔积. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server – SQL 2008.我的用户位于服务器上没有登录的数
- 如何在sql server中从长度为n的单词构建2 ^ n更改单词
- SQL Server 快速生成汉字的首拼字母的函数(经典)
- sql-server-2008 – 动态数据透视表中的行和列总数
- sql-server – 在SQL Server 2008中加密SSN的最佳方法是什么
- neo4j – 以Cypher格式导出整个数据库(ASCII文本)?
- LINQ:Distinct和Orderby
- 本地化 – 从数据库字段显示本地化的邮政/物理地址
- Firebase密钥是否对整个数据库都是唯一的?
- SQL Server 2005获取任何一个月的任何月份的第一个和最后一
