zoukankan      html  css  js  c++  java
  • 笛卡尔集基本原理,等值连接,不等值连接,外连接,自连接

    

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

     

     

     

     

     

  • 相关阅读:
    python连接SMTP的TLS(587端口)发邮件python发邮件(带认证,587端口)202010
    JAVA抓取通过JS渲染的网站(动态)网页数据
    moviepy音视频剪辑:与大小相关的视频变换函数详解
    区块链知识博文1: 共识算法之争(PBFT,Raft,PoW,PoS,DPoS,Ripple)
    MoviePy v2.0.0.dev1尚不成熟,不建议大家使用
    区块链学习2:一些概念性的基础知识笔记
    老猿学5G:3GPP 5G规范中的URI资源概念
    区块链学习1:Merkle树(默克尔树)和Merkle根
    老猿Python博客文章目录索引
    老猿学5G:融合计费场景的Nchf_ConvergedCharging_Create、Update和Release融合计费消息交互过程
  • 原文地址:https://www.cnblogs.com/brucemengbm/p/6739569.html
Copyright © 2011-2022 走看看