zoukankan      html  css  js  c++  java
  • 数据库——子查询和多表查询

    数据准备

    子查询

    什么是子查询:查询中的查询即为子查询,一般使用括号将子查询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;

  • 相关阅读:
    kubernetes进阶(一) kubectl工具使用详解
    二进制安装kubernetes(七) 部署知识点总结
    1024程序员节:这就是国内开发者的现状?
    php 伪协议
    浅谈 PHP 与手机 APP 开发(API 接口开发)
    比RBAC更好的权限认证方式(Auth类认证)
    PHP获得毫秒数
    2020年PHP面试题附答案(实战经验)
    分享几套2019年各大公司最新的PHP面试题,几斤几两一试便知
    PHP面试题2019年百度工程师面试题及答案解析
  • 原文地址:https://www.cnblogs.com/lyxcode/p/9454217.html
Copyright © 2011-2022 走看看