日期:2014-05-16  浏览次数:20532 次

oracle笔记(十四)Oracle的高级查询2

1、? 交叉联接

 交叉连接即笛卡儿乘积,是指两个关系中所有记录的任意组合。一般情况下,交叉查询是没有实际意义的。

SQL> select * from emp e cross join dept d;

备注:可以添加where子句筛选出有意义的数据。建议不使用。

2、? 自连接查询

如果在一个连接查询中,涉及到的两个表都是同一个表,这种查询称为自连接查询。同一张表在FROM字句中多次出现,为了区别该表的每一次出现,需要为表定义一个别名。自连接是一种特殊的内连接,它是指相互连接的表在物理上为同一张表,但可以在逻辑上分为两张表。

  例如:要求检索出员工编号为7369的上司的详细信息,查询语句为

 SQL> select e1.* from emp e inner join emp e1 on e.mgr=e1.empno where e.empno=7369;

注意:对于连接查询中使用到的 inner outer是可以省略的。但为规范最好不要省略。

提高部分:

SQL> select * from emp e inner join dept d on e.deptno(+)=d.deptno;的理解?

l????????? 使用外连接可以查询不满足连接条件的数据。

l????????? 外连接的符号是 (+)

l????????? NATURAL JOIN 子句创建等值连接时,可以使用 USING 子句指定等值连接中需要用到的列