Oracle中sql特殊语句 where后面的字段后面加(+)

在编程过程当中,忽然看到有一段SQL语句中where的字段后面跟着(+),以前没写过这样的sql语句,于是起了好奇之心,想探究一下这个语句的作用是什么。

举一个例子,如SQL:

select a.*,b.* FROM tmp_0813001 a,tmp_0813002 b where a.id=b.id(+) ;

这种语句的写法相当于sql语句中的外连接,下面分析一下。

创建两张临时表,tmp_0813001 和 tmp_0813002,用于测试。

     

     

1.如果是在等号右侧字段的后面加(+),是左外连接,相当于普通SQL里的left join

select a.*,b.* FROM tmp_0813001 a,tmp_0813002 b where a.id=b.id(+) ;

   

select a.*,b.* FROM tmp_0813001 a left join tmp_0813002 b on a.id=b.id;

    

上面两条SQL语句查询结果是一样的。 


2.如果是在等号左侧字段的后面加(+),是右外连接,相当于普通SQL里的right join

select a.*,b.* FROM tmp_0813001 a,tmp_0813002 b where a.id(+)=b.id ;

   

select a.*,b.* FROM tmp_0813001 a right join tmp_0813002 b on a.id=b.id;

    

 上面两条SQL语句查询结果是一样的。

注意:不能在等号的两侧同时加(+),否则会报错:ORA-01468: 一个谓词只能引用一个外部联接的表

    

 这种写法在SQL语句中不常遇到,还是提倡大家用普通的left,right外连接语句,不过可以多了解一下这种写法,对SQL语句理解更透彻一些!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值