zoukankan      html  css  js  c++  java
  • Mysql三天入门(二) 连接查询

    连接查询

    什么是连接查询

    • 在实际开发中,大部分的情况下都不是从单表中查询数据,一般都是多张表联合查询取出最终的结果。

    连接查询的分类

    • 根据语法出现的年代来划分的话,包括:
      • SQL92(一些老的DBA可能还在使用这种语法。DBA:DataBase Administrator,数据库管理员)
      • SQL99(比较新的语法)
    • 根据表的连接方式来划分,包括:
      • 内连接:
        • 等值连接
        • 非等值连接
        • 自连接
      • 外连接:
        • 左外连接(左连接)
        • 右外连接(右连接)
      • 全连接(这个不讲,很少用!)

    笛卡尔积现象

    • 当两张表进行连接查询的时候,没有任何条件进行限制,最终的查询结果条数是两张表记录条数的乘积。
    • 关于表的别名:
      • select e.ename,d.dname from emp e,dept d;
      • 表的别名有什么好处?
        1. 执行效率高。
        2. 可读性好。

    避免笛卡尔积现象

    • 当然是加条件进行过滤。
    • 思考:避免了笛卡尔积现象,会减少记录的匹配次数吗?
      • 不会,次数还是56次。只不过显示的是有效记录。

    内连接

    • 等值连接:最大特点是:条件是等量关系。
    • 非等值连接: 最大的特点是:连接条件中的关系是非等量关系。
    • 自连接:最大的特点是:一张表看做两张表。自己连接自己。

    外连接

    • 内连接:
      • 假设A和B表进行连接,使用内连接的话,凡是A表和B表能够匹配上的记录查询出来,这就是内连接。AB两张表没有主副之分,两张表是平等的。
    • 外连接:
      • 假设A和B表进行连接,使用外连接的话,AB两张表中有一张表是主表,一张表是副表,主要查询主表中
        的数据,捎带着查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。
    • 外连接的分类
      • 左外连接(左连接):表示左边的这张表是主表。
      • 右外连接(右连接):表示右边的这张表是主表。
    • 外连接最重要的特点是:主表的数据无条件的全部查询出来。

    写法

    • 内连接
      • 表一 inner join 表二 on 关联条件
      • 做连接查询的时候一定要写上关联条件
      • inner 可以省略
    • 外连接
      • 左外连接
        • 表1 left outer join 表2 on 关联条件
        • 做连接查询的时候一定要写上关联条件
        • outer 可以省略
      • 左外连接(左连接)和右外连接(右连接)的区别:
        • 左连接以左面的表为准和右边的表比较,和左表相等的不相等都会显示出来,右表符合条件的显示,不符合条件的不显示。
        • 右连接恰恰相反,以上左连接和右连接也可以加入outer关键字,但一般不建议这种写法。

    三张表如何连接

    • 表示:A表和B表先进行表连接,连接之后A表继续和C表进行连接。
    select 
    		e.ename,d.dname,s.grade
    	from
    		emp e
    	join
    		dept d
    	on
    		e.deptno = d.deptno
    	join
    		salgrade s
    	on
    		e.sal between s.losal and s.hisal;
    
  • 相关阅读:
    Redis 笔记
    React Native
    docker run 命令
    vue 集成腾讯地图基础api Demo集合
    在uniapp H5项目中使用腾讯地图sdk
    基于UE4/Unity绘制地图
    腾讯位置服务打车乘客端小车平滑移动-安卓篇
    腾讯位置服务定位打卡功能实现
    腾讯位置服务GPS轨迹回放-安卓篇
    腾讯位置服务个性化图层创建及发布
  • 原文地址:https://www.cnblogs.com/thrseven/p/15115607.html
Copyright © 2011-2022 走看看