关于sql语句左连接(右连接)与条件同时存在的总结

1.SQL中左连接on and条件和where条件执行先后顺序

执行顺序:先执行on and条件,再执行where条件

具体是:首先根据on and条件过滤出满足条件的右侧表记录,然后根据关联字段,左侧表再与过滤出的右侧表记录进行连接,

满足关联字段相等,则返回左侧表和右侧表字段信息;若不满足,则返回左侧表字段信息,右侧表字段则显示NULL。

连接出的结果则存入临时表中。最后where条件是对临时表中的数据进行过滤。

左连接:Left join,以左侧表为主,不管on条件是否满足条件,左侧表的所有记录都会返回。

换句说:on and后面的条件对左侧表没有过滤作用,即使加上对左侧表的过滤,也不起作用。

on后面的条件对右侧表的过滤起作用。where条件则对左连接后的临时表数据进行筛选。

举个例子:

String sql = "select * from RESERVATION_INFO as re left join OPENAC_INFO as op on re.CUS_NAME=op.CUS_NAME left join FINPRODUCTS_REGIST as fi on re.CUS_NAME=fi.CUS_NAME";

对于以上sql语句,如需要对主表(左侧表)进行条件筛选,该如何来加条件呢?上面说了左连接中on and和where条件执行的先后顺序,若直接在语句的最后加条件例如and re.CUS_NAME ='张三' where re.CUS_NAME ='张三' 都是不起作用的,因为左连接以左侧表为主,不管on条件是否满足条件,左侧表的所有记录都会返回。此时我们就可以考虑使用子查询了,如:

//String name = "张三";
String sql = "select * from (select * from RESERVATION_INFO where CUS_NAME= "+name+") as re left join OPENAC_INFO as op on re.CUS_NAME=op.CUS_NAME left join FINPRODUCTS_REGIST as fi on re.CUS_NAME=fi.CUS_NAME";

2.SQL的子查询

子查询概念:把一个查询的结果在另一个查询中使用就叫做子查询

1.子查询作为条件时

当我们使用子查询作为条件时,若子查询返回值为多个,则会报以下错误:

"子查询返回的值不止一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。"

此时我们应该使用范围【in】关键字来解决。

2.子查询的分类

  a.独立子查询:可以独立来执行的查询语句做子查询使用

  b.相关子查询:子查询使用了父查询中的列

3.子查询的使用方式

  a.子查询作为条件使用:当父查询需要某个值,就可以用子查询给出。

  b.子查询作为列的值。

select ClassName from MyClass where ClassId=1
select StudentName,Gender,(select ClassName from MyClass where ClassId=1) from Student where ClassId=1

   c.子查询作为结果集

        如使用子查询结果集实现分页:

select top 3 *from Student--第一页
select top 3*from Student where StudentId not in(select top 3 StudentId from Student)--第二页

3.SQL语句中(+)的含义

SQL语句where语句中,在条件后面加了“(+)”,不论把(+)写在等号左边项还是右边项,统称为外连接。

条件关联时,一般只列出表中满足连接条件的数据。如果条件的一边出现(+),则可列出该表中在条件另一侧的数据为空的那些记录。

比如两个表:员工表和工资表。员工表中有总经理、A、B、C四条记录,工资表中只有A、B、C三人的记录。如果写如下语句:

select 姓名,工资 from 员工表,工资表 where 员工表.姓名=工资表.姓名  那么只可能但出A、B、C三人的记录。
如果写成:select 姓名,工资 from 员工表,工资表 where 员工表.姓名(+)=工资表.姓名;
则可列出总经理及A、B、C三人的记录,只不过查询结果中总经理对应的”工资“列值为空。

你可能感兴趣的:(Java,数据库)