【mysql】连接查询

1、连接查询 1.1 什么是连接查询

从一张表中单独查询,称为单表查询

emp表和dept表联合起来查询数据,从emp表中取员工名字,从dept表中取部门名字。

select ename,dname from emp,dept; 这种跨表查询,多张表联合起来查询数据,被称为连接查询。

1.2 连接查询的分类

根据语法的年代分类:
SQL92:1992年的时候出现的语法
SQL99:1999年的时候出现的语法
我们这里重点学习SQL99.(这个过程中简单演示一个SQL92的例子)

根据表连接的方式分类: 内连接: 等值连接 非等值连接 自连接 外连接: 左外连接(左连接) 右外连接(右连接) 全连接(不讲)
1.3 没加条件连接查询

案例:查询每个员工所在部门名称?
mysql> select ename,deptno from emp;

【mysql】连接查询

14 * 4 = 56

 当两张表进行连接查询,没有任何条件限制的时候,最终查询结果条数,是两张表条数的乘积,这种现象被称为:笛卡尔积现象。(笛卡尔发现的,这是一个数学现象。)
1.4 笛卡尔积现象

连接时加条件,满足这个条件的记录被筛选出来!

 select ename,dname from emp,dept where emp.deptno=dept.deptno;
【mysql】连接查询

思考:最终查询的结果条数是14条,但是匹配的过程中,匹配的次数减少了吗?
答:还是56次,只不过进行了四选一。次数没有减少。

注意:通过笛卡尔积现象得出,表的连接次数越多效率越低,尽量避免表的连接次数。

第二种:取别名

select e.ename,d.dname from emp e,dept d where e.deptno=d.deptno;

表起别名。很重要。效率问题。

1.5 内连接之等值连接

案例:查询每个员工所在部门名称,显示员工名和部门名?
emp e和dept d表进行连接。条件是:e.deptno = d.deptno

SQL92语法: select e.ename,d.dname from emp e, dept d where e.deptno = d.deptno;sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面。
SQL99语法: select e.ename,d.dname from emp e join dept d on e.deptno = d.deptno; //inner可以省略(带着inner可读性更好!!!一眼就能看出来是内连接) select e.ename,d.dname from emp e inner join dept d on e.deptno = d.deptno; // 条件是等量关系,所以被称为等值连接。

sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where

SQL99语法: select ... from a join b on a和b的连接条件 where 筛选条件
1.6 内连接之非等值连接

案例:找出每个员工的薪资等级,要求显示员工名、薪资、薪资等级?

mysql> select * from emp; e+-------+--------+-----------+------+------------+---------+---------+--------+| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |+-------+--------+-----------+------+------------+---------+---------+--------+| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 || 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 1600.00 | 300.00 | 30 || 7521 | WARD | SALESMAN | 7698 | 1981-02-22 | 1250.00 | 500.00 | 30 || 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 2975.00 | NULL | 20 |....mysql> select * from salgrade; s+-------+-------+-------+| GRADE | LOSAL | HISAL |+-------+-------+-------+| 1 | 700 | 1200 || 2 | 1201 | 1400 || 3 | 1401 | 2000 || 4 | 2001 | 3000 || 5 | 3001 | 9999 |+-------+-------+-------+

select e.ename,e.sal,s.grade from emp e join salgrade s on e.sal between s.losal and s.hisal;

【mysql】连接查询
你可能想看:
分享给朋友: