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



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;

总结:关于(+),它在那边就以它为标准,让它的数据都显示。上面的截图中的意思是e表中的都显示,以e表为标准。e表和d表连接,因为d.deptno在e.deptno的左边,随意上面的叫左外连接。

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

 

 

 

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

涂作权的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值