【mysql】连接查询

举报
xcc-2022 发表于 2022/11/28 18:58:43 2022/11/28
【摘要】 1、连接查询 1.1 什么是连接查询从一张表中单独查询,称为单表查询emp表和dept表联合起来查询数据,从emp表中取员工名字,从dept表中取部门名字。select ename,dname from emp,dept; 这种跨表查询,多张表联合起来查询数据,被称为连接查询。 1.2 连接查询的分类根据语法的年代分类:SQL92:1992年的时候出现的语法SQL99:1999年的时候出现...

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;

image-20221030091106877

14 * 4 = 56

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

1.4 笛卡尔积现象

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

 select ename,dname from emp,dept where emp.deptno=dept.deptno;
image-20221030091502426

思考:最终查询的结果条数是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;

image-20221030103124297
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。