从多张表中提取数据
-
从多张表中提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生
笛卡尔积
。
SELECT empno, ename, dtname FROM t_emp JOIN t_dept;
-
从多张表中提取数据规定了连接条件的表连接语句,就不会出现笛卡尔积
SELECT e.empno, e.ename, d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno;
表连接的分类
- 表连接分为两种: 内连接和外连接
- 内连接是结果集中只保留符合连接条件的记录
- 外连接是不管符不符合连接条件,记录都要保留在结果集中
内连接的简介
- 内连接是最常见的一种表连接,用于查询多张关系表符合连接条件的记录。
- 语法结构(其中
INNER
可以不写)
SELECT ... FROM 表1
[INNER] JOIN 表2 ON 条件
[INNER] JOIN 表3 ON 条件
...;
内连接的多种语法形式
SELECT ... FROM 表1 JOIN 表2 ON 连接条件;
SELECT ... FROM 表1 JOIN 表2 WHERE 连接条件;
SELECT ... FROM 表1,表2 WHERE 连接条件;
内连接练习
- 查询每个员工的工号、姓名、部门名称、底薪、职位、工资等级?
select e.empno,e.ename,d.dname,e.sal,e.job,s