数据库——子查询和多表查询

数据准备

 

 

 

 

子查询

什么是子查询:查询中的查询即为子查询,一般使用括号将子查询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、如果子查询返回多个结果,则使用inanyall

   ain:相当于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运算符

          call(所有的)

         <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、如果子查询返回多个结果,则使用inanyall

   ain:相当于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运算符

          call(所有的)

         <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;

 

posted @ 2018-08-10 11:57  木&子  阅读(1095)  评论(0编辑  收藏  举报