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

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


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

 

 

 

 

 

目录
相关文章
|
存储 编解码 网络协议
SIP极简教程
SIP运行在我们熟知的TCP和UDP协议之上,既可以使用TCP协议通信也可以通过UDP协议通信。SIP是对等协议,一个端既是客户端又是服务端。
1360 1
SIP极简教程
|
NoSQL 数据可视化 关系型数据库
推荐几个好用的redis可视化工具
推荐几个好用的redis可视化工具
17680 1
|
5月前
|
存储 消息中间件 开发框架
如何开发一套ERP系统(附架构图+流程图+代码参考)
ERP系统是企业资源计划的核心工具,有效解决信息孤岛、数据重复等问题,提升管理效率与运营成本控制能力。本文详解ERP系统的核心模块及订单管理模块的开发流程,涵盖功能设计、技术选型与代码示例,助力企业高效搭建信息系统。
|
机器学习/深度学习 前端开发 JavaScript
WebAssembly:让前端性能突破极限的秘密武器
WebAssembly(简称 WASM)作为前端开发的性能加速器,能够让代码像 C++ 一样在浏览器中高速运行,突破了 JavaScript 的性能瓶颈。本文详细介绍了 WebAssembly 的概念、工作原理以及其在前端性能提升中的关键作用。通过与 JavaScript 的配合,WASM 让复杂运算如图像处理、3D 渲染、机器学习等在浏览器中流畅运行。文章还探讨了如何逐步集成 WASM,展示其在网页游戏、高计算任务中的实际应用。WebAssembly 为前端开发者提供了新的可能性,是提升网页性能、优化用户体验的关键工具。
5865 2
WebAssembly:让前端性能突破极限的秘密武器
|
Linux 虚拟化 Windows
完美解决:重新安装VMware Tools灰色。以及共享文件夹的创建(centos8)
这篇文章提供了解决VMware Tools无法重新安装(显示为灰色)问题的步骤,并介绍了如何在CentOS 8上创建和配置VMware共享文件夹。
完美解决:重新安装VMware Tools灰色。以及共享文件夹的创建(centos8)
|
监控 项目管理
软件项目管理:从计划到成功的实践
【8月更文第20天】在快速变化的IT行业中,高效的软件项目管理是确保项目成功的关键。本文将探讨软件项目管理中的几个核心领域:项目计划与估算、风险管理、人员配置与团队建设以及进度控制与成本管理,并通过具体案例加以说明。
1087 2
XMind2022最新版破解激活教程,亲测可用
Xmind 是一款 全功能 的思维导图和头脑风暴软件。像大脑的瑞士军刀一般,助你理清思路,捕捉创意。
14937 1
|
存储 SQL Java
EasyExcel 百万级别数据高效率导入/导出(上)
EasyExcel 百万级别数据高效率导入/导出
5463 1
|
开发框架 安全 Ruby
CVE-2018-3760 Ruby On Rails 路径穿越漏洞
CVE-2018-3760 Ruby On Rails 路径穿越漏洞
366 0
CVE-2018-3760 Ruby On Rails 路径穿越漏洞