MySQL二

1、补充内容:关于查询结果集的去重

  • 关键字distinct
     
    select distinct job from emp;
    
    select ename, distinct job from emp;
    //编译错误,distinct前面不能加字段,distinct只能出现在所有字段的最前面;
    
    select distinct deptno,job from emp;
    //多个字段联合去重;
    
    //统计岗位的数量?
    select count(distinct job) from emp;

     

2、连接查询

什么是连接查询?----多张表关联起来取数据;

  • 在实际开发中,大部分的情况下都不是从单表中查询数据,一般都是多张表联合查询取出最终的结果。
  • 在实际开发中,一般一个业务都会对应多张表,比如:学生和班级,起码两张表; 
  • 如果学生和班级存储到一张表中,数据会存在大量的重复,导致数据的冗余;

 连接查询的分类

  • 根据语法出现的年代来划分,包括:SQL92、SQL99(较新的)
  • 根据表的连接方式来划分,包括:内连接(等值连接、非等值连接、自连接):外连接(左外连接、又外连接)、全连接(很少用);

笛卡尔积现象(笛卡尔乘积现象):

  • 在表的连接查询方面有一种现象 被称为:笛卡尔积现象
    当两张表进行查询的时候,没有任何条件限制,最终的查询结果是两张表记录条数的乘积;
  • 案例:找出每一个员工的部门名称,要求有员工名和部门名;
    emp表中有ename/deptno   dept表中有dname,一共4*14=56条记录,两张表记录条数的乘积;
    select ename,dname from emp,dept;
  • ename,dname表示:ename和dname要联合起来一起显示;
  • 表的别名:执行效率高  可读性好
     select e.ename,d.dname from emp e,dept d;
  • 如何避免笛卡尔积现象?加条件进行过滤
    案例:找出每一个员工的部门名称,要求有员工名和部门名?
    select 
        e.ename ,d.dname 
    from 
        emp e ,dept d 
    where 
        e.deptno = d.deptno;

     

  • 避免了笛卡尔积现象会减少记录的匹配次数吗?
    不会,次数还是56次,不过显示的是有效记录;因此,避免了笛卡尔积现象没有提高执行效率;

 

内连接的等值连接

  • 特点:条件是等量关系
  • 案例:查询每个员工的部门名称,要求显示部门名和员工名?
    select e.ename ,d.dnema from emp e ,dept d where e.deptno = d.deptno;(sql92不常用)
    select e.ename ,d.dname from emp e join dept d on e.deptno = d.deptno;(sql99采用)

     

  • 格式:
    select 字段1,字段2,...
    from   A
    join   B
    on     连接条件
    where  ......

     

内连接的非等值连接

  • 特点:连接条件的关系是非等量关系(大于小于等)
  • 案例:找出每个员工的工资等级,要求显示员工名,工资,工资等级?
    //inner可以省略
    select 
        e.ename ,e.sal, s.grade
    from 
        emp e
    inner join 
        salgrade s
    on 
        e.sal between s.losal and s.hisal;

     

内连接的自连接

  • 特点:一张表看做两张表,自己连接自己
  • 案例:找出每个员工的上级领导,要求显示员工名和对应的领导名;
    //员工的领导编号 = 领导的员工编号
    select 
      e1.ename as '员工名' ,e2.ename as '领导名' 
    from
      emp e1
    inner join 
      emp e2
    where 
      e1.mgr = e2.empno;

     

 

外连接

  •  什么是外连接?和内连接有什么区别?
    内连接:假设A和B表进行连接,使用内连接的话,凡是A表和B表能够匹配上的记录查询出来,这就是内连接。AB两张表没有主副之分,两张表是平等的
    外连接:假设A和B进行连接,使用外连接的话,AB两张表中有一张是主表,一张是副表,主要查询主表中的数据,捎带查询副表,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出null与之匹配;
     

外连接的左外连接(左连接)----left

  • 特点:左边的是主表,右边的是副表。左连接有右连接的写法,右连接有对应的左连接写法;
  • 案例:找出全部员工的上级领导?
    KING没有上级领导为null,如果使用内连接,记录就会匹配不上,就不会显示KING的数据;
    这时可以使用外连接,匹配不上是,显示主表信息;
    //左外连接  outer可以省略
    select 
        e1.ename '员工', e2.ename '领导'
    from 
        emp e1
    left outer join
        emp e2 
    on 
        e1.mgr = e2.empno;
    
    
    
    //改为等效的右连接
    
    select 
        e1.ename '员工', e2.ename '领导'
    from 
        emp e2
    right outer join
        emp e1 
    on 
        e1.mgr = e2.empno;

     

  • 案例:找出哪个部门没有员工?

    select
        d.*
    from 
        emp e
    right join
        dept d
    on
        e.deptno = d.deptno
    where 
        e.empno is null;
    
    
    

     

 

三张表的连接查询

  • 案例:找出每个员工的部门名称以及工资等级:
    A join B join C on ...表示A表和B表先进行连接,连接之后A表和C表进行连接;
    select 
        e.deptno, 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;
    

    案例:找出每个员工的部门名称,工资等级、以及上级领导;
     

    select 
        e.ename '员工', d.dname, s.grade, e1.ename '领导'
    from
        emp e
    join
        dept d  
    on 
        e.deptno = d.deptno
    join
        salgrade s
    on
        e.sal between s.losal and s.hisal
    left join
        emp e1
    on
        e.mgr = e1.empno;

     

 

 

 

 

 

 

 

 

上一篇:selenium基础


下一篇:自定义博客园目录