很多同学在进行表关联的时候,and和where的使用有时候分不清,在这里实操记录下。

创建人员信息表并写入数据

create table tmp.userinfo
(
id string,
name string,
age string,
dept string
);

insert into tmp.userinfo values (\'1\',\'张三\',\'12\',\'1\'),(\'2\',\'张三1\',\'223\',\'2\'),(\'3\',\'张三2\',\'23\',\'3\'),(\'4\',\'张三3\',\'243\',\'4\'),(\'5\',\'张三4\',\'523\',\'5\');

创建部门表并写入数据

create table tmp.deptinfo
(
id string,
name string
);

insert into tmp.deptinfo values(\'1\',\'1\'),(\'2\',\'2\'),(\'3\',\'3\'),(\'4\',\'4\'),(\'5\',\'5\'),(\'6\',\'6\')

  • 现象

查询语句 select u.*,d.* from userinfo u left join deptinfo d on u.dept=d.id and u.age<\'23\';

结果如下:

\"\"

 

查询语句 select u.*,d.* from userinfo u left join deptinfo d on u.dept=d.id where u.age<\'23\';

结果如下:

\"\"

 

  • 解释

在join中on是起到关联关系的连接作用,on后面指定的是关联条件,比如select * from A  a left join B  b on a.clientno=b.clientno 就是当两张表clientno相同才能关联上,

如果后面再跟上and的话,就是要同时满足这两个条件,如  select * from A  a left join B  b on a.clientno=b.clientno and a.sex=b.sex,其实这个可以将on后面看成一个整体:select * from A  a left join B  b on (a.clientno=b.clientno and a.sex=b.sex)

  • 总结

select u.*,d.* from userinfo u left join deptinfo d on u.dept=d.id and u.age<\'23\';
-- 对于left join,on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录,on后面的只作为关联条件。

select u.*,d.* from userinfo u left join deptinfo d on u.dept=d.id where u.age<\'23\';
-- where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉

比较好的写法
select u.*,d.* from (select * from userinfo where age<\'23\') u left join deptinfo d on u.dept=d.id;

如有纰漏,欢迎指正。

收藏 打印