数据库——子查询和多表查询
数据准备
子查询
什么是子查询:查询中的查询即为子查询,一般使用括号将子查询sql括起来,如下SQL语句:
select * from (select * from user_info) users
什么时候用子查询:当在查询过程中需要知道一个已知量的不确定数据时使用子查询
--查询出来姓名为王晓明的所有地址
select * from address where user_id=(select id from user_info where real_name='王晓明');--使用子查询先通过姓名获取id,然后再通过用户id查询地址表
怎么使用子查询
1、=:如果子查询只返回一个结果,则可以使用=,也可以使用in;但是如果确定子查询永远只返回一个结果,则不建议使用in,例如上面SQL语句可变为如下SQL语句
select * from address where user_id in(select id from user_info where real_name='王晓明');
2、如果子查询返回多个结果,则使用in、any、all:
a、in:相当于or连接多个条件
--获取到姓氏为王姓的所有用户的所有地址
select * from address where user_id in(select id from user_info where real_name like '王%');
b、any (某一个的)
<any:小于子查询结果中的某一个,即小于最大的,比如 age <any(12,36,9),这时只要age小于36即可
>any:大于子查询结果中的某一个,即大于最小的,比如age >any(12,36,9),这时只要age大于9即可
=any:等于子查询结果中的某一个,等同于in
注意:any运算符等同于some运算符
c、all(所有的)
<all:小于子查询结果中所有的一个,即小于最小的,比如age <all(12,36,9),这时只要age小于9即可
>all:大于子查询结果中所有的一个,即大于最大的,比如age >all(12,36,9),这时只要age大于36即可
SQL语句判读:
多表查询
多个表关联查询需要依据多表之间列关系将其连接起来,这种连接方式分为三种:内连接(inner join)、外连接(outer join)及交叉连接(cross join)
内连接(inner join)
如果依据多个表之间列关系进行内连接,查询结果集仅包括满足连接条件的数据行。内连接分为等值连接、不等值连接以及自然连接
等值连接:在连接条件中使用等号(=)运算符比较被连接列的列值是否相等,分显式等值连接和隐式等值连接:
显式等值连接:
select ui.*,addr.* from user_info ui [inner] join address addr on ui.id = addr.user_id;
隐式等值连接:
select ui.*,addr.* from user_info ui,address addr where ui.id = addr.user_id;
上面SQL语句执行结果:
不等值连接:
自然连接:
外连接(outer join)
如果依据多表之间列关系进行外连接,查询结果集不仅仅包括满足on连接条件的数据行,还包括不满足on连接条件的数据行。
左外连接(left [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含左表(“left [outer] join”关键字左边的表)不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui left join address addr on ui.id = addr.user_id;
右外连接(right [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含右表(即“right [outer] join”关键字右边的表)不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui right join address addr on ui.id = addr.user_id;
全外连接(full [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含左表(“full [outer] join”关键字左边的表)和右表(“full [outer join”关键字右边的表)中不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui full join address addr on ui.id = addr.user_id;
数据准备
子查询
什么是子查询:查询中的查询即为子查询,一般使用括号将子查询sql括起来,如下SQL语句:
select * from (select * from user_info) users
什么时候用子查询:当在查询过程中需要知道一个已知量的不确定数据时使用子查询
--查询出来姓名为王晓明的所有地址
select * from address where user_id=(select id from user_info where real_name='王晓明');--使用子查询先通过姓名获取id,然后再通过用户id查询地址表
怎么使用子查询
1、=:如果子查询只返回一个结果,则可以使用=,也可以使用in;但是如果确定子查询永远只返回一个结果,则不建议使用in,例如上面SQL语句可变为如下SQL语句
select * from address where user_id in(select id from user_info where real_name='王晓明');
2、如果子查询返回多个结果,则使用in、any、all:
a、in:相当于or连接多个条件
--获取到姓氏为王姓的所有用户的所有地址
select * from address where user_id in(select id from user_info where real_name like '王%');
b、any (某一个的)
<any:小于子查询结果中的某一个,即小于最大的,比如 age <any(12,36,9),这时只要age小于36即可
>any:大于子查询结果中的某一个,即大于最小的,比如age >any(12,36,9),这时只要age大于9即可
=any:等于子查询结果中的某一个,等同于in
注意:any运算符等同于some运算符
c、all(所有的)
<all:小于子查询结果中所有的一个,即小于最小的,比如age <all(12,36,9),这时只要age小于9即可
>all:大于子查询结果中所有的一个,即大于最大的,比如age >all(12,36,9),这时只要age大于36即可
SQL语句判读:
多表查询
多个表关联查询需要依据多表之间列关系将其连接起来,这种连接方式分为三种:内连接(inner join)、外连接(outer join)及交叉连接(cross join)
内连接(inner join)
如果依据多个表之间列关系进行内连接,查询结果集仅包括满足连接条件的数据行。内连接分为等值连接、不等值连接以及自然连接
等值连接:在连接条件中使用等号(=)运算符比较被连接列的列值是否相等,分显式等值连接和隐式等值连接:
显式等值连接:
select ui.*,addr.* from user_info ui [inner] join address addr on ui.id = addr.user_id;
隐式等值连接:
select ui.*,addr.* from user_info ui,address addr where ui.id = addr.user_id;
上面SQL语句执行结果:
不等值连接:
自然连接:
外连接(outer join)
如果依据多表之间列关系进行外连接,查询结果集不仅仅包括满足on连接条件的数据行,还包括不满足on连接条件的数据行。
左外连接(left [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含左表(“left [outer] join”关键字左边的表)不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui left join address addr on ui.id = addr.user_id;
右外连接(right [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含右表(即“right [outer] join”关键字右边的表)不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui right join address addr on ui.id = addr.user_id;
全外连接(full [outer] join):返回的结果集中不仅包含表之间满足on连接条件的全部数据行,还包含左表(“full [outer] join”关键字左边的表)和右表(“full [outer join”关键字右边的表)中不满足on连接条件的数据行;
select ui.*,addr.* from user_info ui full join address addr on ui.id = addr.user_id;
交叉连接(cross join)
左表(“cross join”关键字左边的表)中的每一行与右表(“cross join”关键字右边的表)中的所有行组合,交叉联接的结果是一个笛卡尔积。
select ui.*,addr.* from user_info ui cross join address addr;
交叉连接(cross join)
左表(“cross join”关键字左边的表)中的每一行与右表(“cross join”关键字右边的表)中的所有行组合,交叉联接的结果是一个笛卡尔积。
select ui.*,addr.* from user_info ui cross join address addr;