在编程过程当中,忽然看到有一段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语句理解更透彻一些!