码迷,mamicode.com
首页 > 其他好文 > 详细

笛卡尔集基本原理,等值连接,不等值连接,外连接,自连接

时间:2014-10-10 02:18:04      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   os   ar   数据   sp   div   2014   



1 笛卡尔集基本原理

两个表如果笛卡尔集运算

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

(2)列是两个表合集

案例:

错误查询方式:

select count(e.EMPNO)

from emp e,dept d;

bubuko.com,布布扣

正确查询方式:

select count(e.EMPNO)

from emp e,dept d

where e.deptno = d.deptno;

bubuko.com,布布扣

2.等值连接

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

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

from emp e,dept d

where e.deptno = d.deptno;

bubuko.com,布布扣

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来替换)

bubuko.com,布布扣

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;

bubuko.com,布布扣

分析:

我们的期望想把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;

bubuko.com,布布扣

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(+);

bubuko.com,布布扣

 

 

 

 

 

笛卡尔集基本原理,等值连接,不等值连接,外连接,自连接

标签:style   blog   http   os   ar   数据   sp   div   2014   

原文地址:http://blog.csdn.net/tototuzuoquan/article/details/39947045

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!