视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
笛卡尔集基本原理,等值连接,不等值连接,外连接,自连接
2020-11-09 14:44:06 责编:小采
文档


1 笛卡尔集基本原理 两个表如果笛卡尔集运算 (1)行数是两个表行数相乘的结果 (2)列是两个表合集 案例: 错误查询方式: select count(e.EMPNO) from emp e,dept d; 正确查询方式: select count(e.EMPNO) from emp e,dept d where e.deptno = d.deptno; 2.等

1 笛卡尔集基本原理

两个表如果笛卡尔集运算

(1)行数是两个表行数相乘的结果

(2)列是两个表合集

案例:

错误查询方式:

select count(e.EMPNO)

from emp e,dept d;

正确查询方式:

select count(e.EMPNO)

from emp e,dept d

where e.deptno = d.deptno;

2.等值连接

Eg:查询员工信息,员工号,姓名,月薪,部门名称

select e.empno,e.ename,e.sal,d.dname

from emp e,dept d

where e.deptno = d.deptno;

3.不等值连接

Eg:查询员工信息,员工号,姓名,月薪,薪水级别

select e.empno,e.ename,e.sal,s.grade

from emp e,salgrade s

where e.sal >= s.losal and e.sal <=s.hisal;(可以用between and来替换)

4.外连接

Eg:按部门统计员工人数:部门号部门名称各部门人数

思路:

A:求各部门的人数..要把各个部门数据划分开….,要分组…..

B:各部门人数,要关联员工表(因为部门人数是由员工表确定的,所以还要检索员工表)

所以需要多表查询

现象一(漏掉了一个部门)

select d.deptno,d.dname,count(e.empno)

from dept d,emp e

where d.deptno = e.deptno

group by d.deptno,d.dname;

分析:

我们的期望想把40号部门给统计出来...

40号部门没有被统计出来的原因: 员工表中没有40号部门的员工...d.deptno = e.deptno (d.40 = e.40)

本质:等值条件不满足...

外连接技术出现的原因

+左外连接: +号在..=号的右边,左外连接....

+右外连接: +号在..=号的左边,左外连接....

我想把部门表的所有列都显示出来, 就需要找到部门表..在对方写(+)

左外连接:

select d.deptno,d.dname,count(e.empno)

from dept d,emp e

where d.deptno = e.deptno(+)

group by d.deptno,d.dname;

5 自连接

-- 查询员工信息 ,老板信息

显示: ****的老板是****

---思路1: 员工信息查员工表

查老板信息,还要查员工表...

---思路2 员工表的老板是 老板表的员工

selecte.ename, b.ename

fromemp e, emp b

wheree.mgr = b.empno

自连接案例:

select e.ename || '的老板是'||nvl(b.ename,'他自己')

from emp e,emp b

where e.mgr = b.empno(+);

下载本文
显示全文
专题