
内连接的连接结果仅包含符合连接条件的行,参与连接的两个表都必须符合连接条件;而外连接的连接结果不仅包含了符合连接条件的行,同时还包括不符合自身条件的行,其中还包括左外连接、右外连接以及全外连接。
2、注意事项不同
内连接需要注意区分在嵌套查询时使用的any以及all的区别;外连接不需要区分,左表和右表都不受限制,所有记录都显示,两个表不足的地方可用null进行填充。
内连接又分为等值连接、自然连接和不等连接三种。 \x0d\x0a\x0d\x0a外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN)和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。 \x0d\x0a\x0d\x0a交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 \x0d\x0a\x0d\x0a连接 *** 作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。 \x0d\x0a\x0d\x0a无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接连接。例如: \x0d\x0a\x0d\x0aSELECT p1.pub_id,p2.pub_id,p1.pr_info \x0d\x0aFROM pub_info AS p1 INNER JOIN pub_info AS p2 \x0d\x0aON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) \x0d\x0a\x0d\x0a(一) 内连接 \x0d\x0a\x0d\x0a内连接查询 *** 作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种: \x0d\x0a\x0d\x0a1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。 \x0d\x0a\x0d\x0a2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、、!&lt和。 \x0d\x0a\x0d\x0a3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。 \x0d\x0a\x0d\x0a例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社: \x0d\x0a\x0d\x0aSELECT * \x0d\x0aFROM authors AS a INNER JOIN publishers AS p \x0d\x0aON a.city=p.city \x0d\x0a\x0d\x0a又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state): \x0d\x0a\x0d\x0aSELECT a.*,p.pub_id,p.pub_name,p.country \x0d\x0aFROM authors AS a INNER JOIN publishers AS p \x0d\x0aON a.city=p.city \x0d\x0a\x0d\x0a(二) 外连接 \x0d\x0a\x0d\x0a内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。 \x0d\x0a\x0d\x0a如下面使用左外连接将论坛内容和作者信息连接起来: \x0d\x0a\x0d\x0aSELECT a.*,b.* FROM luntan LEFT JOIN usertable as b \x0d\x0aON a.username=b.username \x0d\x0a\x0d\x0a下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市: \x0d\x0a\x0d\x0aSELECT a.*,b.* \x0d\x0aFROM city as a FULL OUTER JOIN user as b \x0d\x0aON a.username=b.username \x0d\x0a\x0d\x0a(三) 交叉连接 \x0d\x0a\x0d\x0a交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。 \x0d\x0a\x0d\x0a例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于6*8=48 行。 \x0d\x0a\x0d\x0aSELECT type,pub_name \x0d\x0aFROM titles CROSS JOIN publishers \x0d\x0aORDER BY type \x0d\x0a\x0d\x0a介绍了表连接,更确切的说是inner joins内连接. \x0d\x0a内连接仅选出两张表中互相匹配的记录.因此,这会导致有时我们需要的记录没有包含进来。 \x0d\x0a为更好的理解这个概念,我们介绍两个表作演示。苏格兰议会中的政党表(party)和议员表 (msp)。 \x0d\x0a\x0d\x0aparty(Code,Name,Leader) \x0d\x0aCode: 政党代码 \x0d\x0aName: 政党名称 \x0d\x0aLeader: 政党领袖 \x0d\x0a\x0d\x0amsp(Name,Party,Constituency) \x0d\x0aName: 议员名 \x0d\x0aParty: 议员所在政党代码 \x0d\x0aConstituency: 选区表的连接是指在一个SQL语句中通过表与表之间的关连 从一个或多个表中检索相关的数据 大体上表与表之间的连接主要可分四种 分别为相等连接 外连接 不等连接和自连接 本文将主要从以下几个典型的例子来分析Oracle表的四种不同连接方式:
相等连接
通过两个表具有相同意义的列 可以建立相等连接条件
只有连接列上在两个表中都出现且值相等的行才会出现在查询结果中
例 查询员工信息以及对应的员工所在的部门信息
SELECT * FROM EMP DEPTSELECT * FROM EMP DEPT WHERE EMP DEPTNO = DEPT DEPTNO
REM 显示工资超过 的员工信息以及对应的员工的部门名称
外连接
对于外连接 Oracle中可以使用 (+) 来表示 i可以使用LEFT/RIGHT/FULL OUTER JOIN 下面将配合实例一一介绍 除了显示匹配相等连接条件的信息之外 还显示无法匹配相等连接条件的某个表的信息
外连接采用(+)来识别
A) 左条件(+) = 右条件
代表除了显示匹配相等连接条件的信息之外 还显示右条件所在的表中无法匹配相等连接条件的信息
此时也称为 右外连接 另一种表示方法是:
SELECT FROM 表 RIGHT OUTER JOIN 表 ON 连接条件
B) 左条件 = 右条件(+)
代表除了显示匹配相等连接条件的信息之外 还显示左条件所在的表中无法匹配相等连接条件的信息
此时也称为 左外连接
SELECT FROM 表 LEFT OUTER JOIN 表 ON 连接条件
例 显示员工信息以及所对应的部门信息
无法显示没有部门的员工信息
无法显示没有员工的部门信息
SELECT * FROM EMP DEPT WHERE EMP DEPTNO = DEPT DEPTNO
直接做相等连接:
SELECT * FROM EMP JOIN DEPT ON EMP DEPTNO = DEPT DEPTNO
REM 显示员工信息以及所对应的部门信息 显示没有员工的部门信息
SELECT * FROM EMP DEPT WHERE EMP DEPTNO(+) = DEPT DEPTNOSELECT * FROM EMP RIGHT OUTER JOIN DEPT ON EMP DEPTNO = DEPT DEPTNO
REM 显示员工信息以及所对应的部门信息 显示没有部门的员工信息
SELECT * FROM EMP DEPT WHERE EMP DEPTNO = DEPT DEPTNO(+)SELECT * FROM EMP LEFT OUTER JOIN DEPT ON EMP DEPTNO = DEPT DEPTNO
不等连接
两个表中的相关的两列进行不等连接 比较符号一般为><BEEEN AND
REM SALGRADE DESC SALGRADE SELECT * FROM SALGRADE
REM 显示员工的编号 姓名 工资 以及工资所对应的级别
SELECT EMPNO ENAME SAL SALGRADE * FROM SALGRADE EMP WHERE EMP SAL BEEEN LOSAL AND HISAL
REM 显示雇员的编号 姓名 工资 工资级别 所在部门的名称
SELECT EMPNO ENAME SAL GRADE DNAME FROM EMP DEPT SALGRADE WHERE EMP DEPTNO = DEPT DEPTNO AND EMP SAL BEEEN LOSAL AND HISAL
自连接
自连接是数据库中经常要用的连接方式 使用自连接可以将自身表的一个镜像当作另一个表来对待 从而能够得到一些特殊的数据 下面介绍一下自连接的方法:
将原表复制一份作为另一个表 两表做笛卡儿相等连接
例 显示雇员的编号 名称 以及该雇员的经理名称
SELECT WORKER ENAME WORKER MGR MANAGER EMPNO MANAGER ENAME FROM EMP WORKER EMP MANAGER
lishixinzhi/Article/program/Oracle/201311/16733
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)