设为首页 加入收藏

TOP

Oracle学习(5):多表查询(二)
2015-11-21 01:54:05 来源: 作者: 【 】 浏览:2
Tags:Oracle 学习 查询
d,emp e
3 where d.deptno=e.deptno(+)
4 group by d.deptno,d.dname
5 order by 1;


DEPTNO DNAME 人数
---------- -------------- ----------
10 ACCOUNTING 3
20 RESEARCH 5
30 SALES 6
40 OPERATIONS 0


SQL> host cls

自连接

SQL> --自连接:
SQL> --查询员工信息:***的老板是****
SQL> select * from emp;


EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- -------- --------- ---------- -------------- ----- ---------- ----------
7369 SMITH CLERK 7902 17-12月-80 800 20
7499 ALLEN SALESMAN 7698 20-2月 -81 1600 300 30
7521 WARD SALESMAN 7698 22-2月 -81 1250 500 30
7566 JONES MANAGER 7839 02-4月 -81 2975 20
7654 MARTIN SALESMAN 7698 28-9月 -81 1250 1400 30
7698 BLAKE MANAGER 7839 01-5月 -81 2850 30
7782 CLARK MANAGER 7839 09-6月 -81 2450 10
7788 SCOTT ANALYST 7566 13-7月 -87 3000 20
7839 KING PRESIDENT 17-11月-81 5000 10
7844 TURNER SALESMAN 7698 08-9月 -81 1500 0 30
7876 ADAMS CLERK 7788 13-7月 -87 1100 20
7900 JAMES CLERK 7698 03-12月-81 950 30
7902 FORD ANALYST 7566 03-12月-81 3000 20
7934 MILLER CLERK 7782 23-1月 -82 1300 10


已选择14行。


SQL> select e.ename||'的老板是'||b.ename
2 from emp e, emp b
3 where e.mgr=b.empno;


E.ENAME||'的老板是'||B.ENAME
----------------------------
FORD的老板是JONES
SCOTT的老板是JONES
JAMES的老板是BLAKE
TURNER的老板是BLAKE
MARTIN的老板是BLAKE
WARD的老板是BLAKE
ALLEN的老板是BLAKE
MILLER的老板是CLARK
ADAMS的老板是SCOTT
CLARK的老板是KING
BLAKE的老板是KING
JONES的老板是KING
SMITH的老板是FORD


已选择13行。


SQL> --自连接:通过表的别名,将同一张表视为不同的表,再利用别的连接操作
SQL> --自连接 一般只适用于小表(因为产生的笛卡尔表数据量太过庞大)
SQL> host cls

层次查询

SQL> --层次查询:只有一张表
SQL> -- 同一张表的前后两次操作进行连接
SQL> select level,empno,ename,mgr
2 from emp
3 connect by prior empno=mgr
4 start with mgr is null;


LEVEL EMPNO ENAME MGR
---------- ---------- -------- ----------
1 7839 KING
2 7566 JONES 7839
3 7788 SCOTT 7566
4 7876 ADAMS 7788
3 7902 FORD 7566
4 7369 SMITH 7902
2 7698 BLAKE 7839
3 7499 ALLEN 7698
3 7521 WARD 7698
3 7654 MARTIN 7698
3 7844 TURNER 7698
3 7900 JAMES 7698
2 7782 CLARK 7839
3 7934 MILLER 7782


已选择14行。


SQL> ed
已写入 file afiedt.buf


1 select level,empno,ename,mgr
2 from emp
3 connect by prior empno=mgr
4 start with mgr is null
5* order by 1
SQL> /


LEVEL EMPNO ENAME MGR
---------- ---------- -------- ----------
1 7839 KING
2 7566 JONES 7839
2 7698 BLAKE 7839
2 7782 CLARK 7839
3 7902 FORD 7566
3 7521 WARD 7698
3 7900 JAMES 7698
3 7934 MILLER 7782
3 7499 ALLEN 7698
3 7788 SCOTT 7566
3 7654 MARTIN 7698
3 7844 TURNER 7698
4 7876 ADAMS 7788
4 7369 SMITH 7902


已选择14行。


SQL> /*
SQL> 第一次:7839
SQL> 第二次:where mgr=7839
SQL> 7566 7698 7782
SQL> 第三次:where mgr in (7566 7698 7782)
SQL> */
SQL> spool off
首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Mongodb-基本命令 下一篇记一次UNDO表空间超90%的处理

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: