SQL语句复习【专题四】

SQL语句复习【专题四】sql

多表查询 sql 92
多表查询 sql9二、sql99 标准
--查询全部员工的姓名,部门编号,部门名称
select * from emp
select * from dept
--笛卡尔集
select * from emp, dept
--消除笛卡尔集中的冗余的数据
select *
from emp, dept
where emp.deptno=dept.deptno--表的链接查询条件spa

等值链接查询
--查询全部员工的姓名,部门编号,部门名称
注意:若是多个表间存在相同的字段的名称,那么必须指明显示的字段属于哪一张表。
select ename, emp.deptno,dname
from emp, dept
where emp.deptno=dept.deptno效率

给表起别名:注意:给表起别名不能使用 as 。一旦给表起了别名,那么本来的表的名称就不能再使用。
select ename, e.deptno,dname
from emp e, dept d
where e.deptno=d.deptnoselect

select ename, e.deptno,dname
from emp e, dept d
where e.deptno <> 10 and e.deptno=d.deptno语法

sql 92中,表的链接条件: 在where 中书写 表链接的条件。where 中既能够写行过滤,也要写 表链接。
--非等值链接
--查询全部员工的姓名,职位,薪水,薪水等级 emp 和 salgrade 两个表的多表查询
select *
from emp e, salgrade s
--非等值链接
select e.ename, e.job, e.sal ,s.grade
from emp e, salgrade s
where e.sal >=s.losal and e.sal <= s.hisal
--尽可能将全部的显式的字段,都使用表名引用 ,能够提升访问的效率。引用

自链接
--查询 员工的编号,名字,员工的上级的编号,上级的名字
select * from emp
将一张表 看做两张表。
--一张员工表 emp。想象成一张做为领导的上级的表。
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno数据

外链接 【左右外链接】
左外链接
--查看不知足条件的记录
--查询 员工的编号,名字,员工的上级的编号,上级的名字,包含没有上级的员工
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno(+)--左外链接,就是将左表的不知足条件的内容也显示出来。查询

右外链接
--查询 员工的编号,名字,员工的上级的编号,上级的名字,包含没有下级的员工的信息
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr(+)=e2.empno--右外链接,就是将右表的不知足条件的内容也显示出来。join

--查询部门的全部信息,以及每一个部门的平均工资,包含没有员工的部门
select d.*,avg(sal)
from emp e, dept d
where e.deptno(+)=d.deptno--右外链接
group by d.deptno,d.dname,d.locoss

三表链接
--查询20号部门的员工的编号,姓名,薪水,部门名称,薪水等级。
select d.deptno, e.empno,e.ename,e.sal,d.dname,s.grade
from emp e, dept d, salgrade s
where d.deptno=20 and e.deptno=d.deptno and e.sal >=s.losal and e.sal<= s.hisal

n张表,至少须要几个链接条件? 须要n-1 个链接条件

sql 92:链接条件和 行过滤条件都在where子句中 书写。
sql 99:表的链接条件 和 行过滤条件分开了。where 只作行过滤。表的链接条件在其余的地方进行。
--交叉链接 cross join 和笛卡尔集是同样的
--sql92
select *
from emp e, dept d
--sql 99
select *
from emp e cross join dept d

--查询全部员工的姓名,部门编号,部门名称
--sql92
select e.ename,e.deptno,d.dname
from emp e, dept d
where e.deptno=d.deptno

天然链接 natural join 等值链接:
链接条件被隐式指定,自动使用两个进行天然链接的表中的相同的字段进行等值链接。做为链接条件的列,不能指定该列的表的限定。语法的要求。
优势:不须要指明链接条件,条件是隐式指定的。
缺点:不能指定链接条件,若是多个表中有多个相同的字段,那么会自动使用多个字段进行等值链接,不够灵活。只能作等值链接。
select e.ename,deptno,d.dname
from emp e
natural join dept d

Using 子句:只能作等值链接。须要链接的表中存在相同的字段,能够显式指定多表之间的等值链接条件,能够指定多个字段进行等值链接。
--sql 99
select e.ename,deptno,d.dname
from emp e
inner join dept d--内链接 inner 能够省略
Using(deptno)

select e.ename,deptno,d.dname
from emp e
join dept d--内链接 inner 能够省略
Using(deptno)

on 子句链接:既能够等值链接也能够不等值链接
--查询30部分的员工的编号,姓名,部门名称
--sql 92
select d.deptno, e.empno,e.ename,d.dname
from emp e, dept d
where d.deptno=30 and e.deptno=d.deptno
--sql 99
select d.deptno, e.empno,e.ename,d.dname
from emp e join dept d
on e.deptno=d.deptno---等值链接
where d.deptno=30

--查询10部门员工的姓名,薪水等级---不等值链接
--sql 92
select e.deptno,e.ename, s.grade
from emp e, salgrade s
where e.deptno=10 and e.sal >= s.losal and e.sal <= s.hisal
--sql 99
select e.deptno,e.ename, s.grade
from emp e join salgrade s
on e.sal >= s.losal and e.sal<=s.hisal
where e.deptno=10

自链接
--查询 员工的编号,名字,员工的上级的编号,上级的名字
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 join emp e2
on e1.mgr=e2.empno

外链接
1)左外链接 left [outer] join 左边的表的不满链接条件的信息所有显式
2)右外链接 right [outer] join 右边的表的不满链接条件的信息所有显式
3)全外链接 full [outer] join 左边和右边的表的不满链接条件的信息所有显式
--sql 99 左外 包含没有上级的员工的信息
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno(+)
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 left outer join emp e2
on e1.mgr=e2.empno

--sql 99 右外 包含没有下级的员工的信息
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr(+)=e2.empno
--sql 99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 right join emp e2
on e1.mgr=e2.empno

--sql 99 全外 包含没有上下级的员工的信息
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 full join emp e2
on e1.mgr=e2.empno

--sql 99 查询部门的全部信息,以及每一个部门的平均工资,包含没有员工的部门
--sql 92
select d.*,avg(sal)
from emp e, dept d
where e.deptno(+)=d.deptno
group by d.deptno,d.dname,d.loc
--sql99
select d.*,avg(sal)
from emp e right outer join dept d
on e.deptno=d.deptno
group by d.deptno,d.dname,d.loc

--查询20号部门的员工的编号、姓名、薪水、部门名称,薪水等级
--三表
--sql 92
select d.deptno ,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e, dept d, salgrade s
where d.deptno=20 and e.deptno=d.deptno and e.sal >= s.losal and e.sal<=s.hisal

--sql 99 natural join 隐式链接的字段不能添加表的限定
select deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e natural join dept d join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where deptno=20

--sql 99 Using + on Using 等值链接的字段,不要指定表的限定
select deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e join dept d
Using(deptno)
join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where deptno=20

--sql 99 on on 中的等值链接部分,若是显式等值链接的字段,须要对字段指定属于哪个表。
select d.deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e join dept d
on e.deptno=d.deptno
join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where d.deptno=20

相关文章
相关标签/搜索