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



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

时间: 2024-10-24 16:15:26

笛卡尔集基本原理,等值连接,不等值连接,外连接,自连接的相关文章

CROSS JOIN连接用于生成两张表的笛卡尔集

将两张表的情况全部列举出来 结果表: 列= 原表列数相加 行= 原表行数相乘 CROSS JOIN连接用于生成两张表的笛卡尔集. 在sql中cross join的使用: 1.返回的记录数为两个表的记录数乘积. 2.将A表的所有行分别与B表的所有行进行连接. 例如: tableA r1 r2 A B C D tableB r3 r4 1 2 3 4 select * from tableA cross join tableB; return: r1 r2 r3 r4 r1 r2 1 2 r1 r2

数据库编程1 Oracle 过滤 函数 分组 外连接 自连接

[本文谢绝转载原文来自http://990487026.blog.51cto.com] <大纲> 数据库编程1 Oracle 过滤 函数 分组 外连接 自连接 本文实验基于的数据表: winsows安装好Oracle11g之后,开始实验 SQLplus 登陆 ORacle sqlplus 退出的方式 查看用户之下有什么表 查看表的所有记录,不区分大小写 设置SQLplus行宽,页宽,列宽: 清屏命令 select as 语法 1,as别名的使用 2,没有引号带有空格的别名,无法识别: 3,带有

数据库编程2 Oracle 过滤 函数 分组 外连接 自连接

[本文谢绝转载原文来自http://990487026.blog.51cto.com] 续:数据库编程1 Oracle 过滤 函数 分组 外连接 自连接 where like模糊查询,查询员工姓名是4个字母 SQL> select * from emp where ename like '____';      EMPNO ENAME                JOB                       MGR HIREDATE          SAL       COMM    

MapReduce实现等值连接,左外连接,右外连接,全外连接

#测试数据: # more user.txt(用户ID,用户名) [java] view plain copy 1   lavimer 2   liaozhongmin 3   liaozemin #more post.txt(用户ID,帖子ID,标题) [java] view plain copy 1   1   java 1   2   c 2   3   hadoop 4   4   hive 5   5   hbase 5   6   pig 5   7   flume #等值连接结果如

内连接 外连接 自连接 交叉连接

======================================================== My SQL如下: ======================================================== 1.内联接(典型的联接运算,使用像 =  或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students和courses表中学生标识号相同的所有行. 2.外联接.外联接

数据库SQL Server2012笔记(四)——多表查询、子查询、分页查询、用查询结果创建新表和外连接

1.多表查询 1)笛卡尔集: select  *  from  表名1,表名2 select  *  from  表名1,表名2  where   表名1.字段名=表名2.字段名 注: 若有两张表有相同名字的字段,则使用时需带表名(别名). order  by  置于where 条件之后. 2)自连接:同一张表的连接查询,将一张表视为两张表或多张表. eg:显示公司每个员工名字和他的上级的名字.将emp表看做两张表worker和boss select  worker.ename  雇员,boss

[Oracle]多表连接技术-交叉连接、非等值连接、等值连接、外连接

交叉连接(笛卡尔积) 连接条件无效或者被省略,两个表的所有行都发生连接,所有行的组合都会返回(n*m) 非等值连接 原始的2个库结构 等值连接 外连接 左外 右外(基本不用) 全连 自连接 END 原文地址:https://www.cnblogs.com/leoshi/p/12573840.html

NOIP2011pj表达式的值[树形DP 笛卡尔树]

题目描述 对于1 位二进制变量定义两种运算: 运算的优先级是: 先计算括号内的,再计算括号外的. “× ”运算优先于“⊕”运算,即计算表达式时,先计算× 运算,再计算⊕运算.例如:计算表达式A⊕B × C时,先计算 B × C,其结果再与 A 做⊕运算. 现给定一个未完成的表达式,例如+(*_),请你在横线处填入数字0 或者1 ,请问有多少种填法可以使得表达式的值为0 . 输入输出格式 输入格式: 输入文件名为exp.in ,共 2 行. 第1 行为一个整数 L,表示给定的表达式中除去横线外的运

[转]sql语句中出现笛卡尔乘积 SQL查询入门篇

本篇文章中,主要说明SQL中的各种连接以及使用范围,以及更进一步的解释关系代数法和关系演算法对在同一条查询的不同思路. 多表连接简介 在关系数据库中,一个查询往往会涉及多个表,因为很少有数据库只有一个表,而如果大多查询只涉及到一个表的,那么那个表也往往低于第三范式,存在大量冗余和异常. 因此,连接(Join)就是一种把多个表连接成一个表的重要手段. 比如简单两个表连接学生表(Student)和班级(Class)表,如图: 进行连接后如图: 笛卡尔积 笛卡尔积在SQL中的实现方式既是交叉连接(Cr