Oracle数据库之多表查询

前端之家收集整理的这篇文章主要介绍了Oracle数据库之多表查询前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

oracle安装参照: Oracle数据库之安装教程

Oracle数据库总结:

Oracle数据库之基本查询
Oracle数据库之单行函数
Oracle数据库之多行函数
Oracle数据库之多表查询
sql> –等值连接
sql> –查询员工信息:员工号 姓名 月薪 部门名称

sql> select e.empno,e.ename,e.sal,d.dname
2 from emp e,dept d
3 where e.deptno=d.deptno;

  1. EMPNO ENAME SAL DNAME
  2. ---------- ---------- ---------- --------------
  3. 7369 SMITH 800 RESEARCH
  4. 7499 ALLEN 1600 SALES
  5. 7521 WARD 1250 SALES
  6. 7566 JONES 2975 RESEARCH
  7. 7654 MARTIN 1250 SALES
  8. 7698 BLAKE 2850 SALES
  9. 7782 CLARK 2450 ACCOUNTING
  10. 7788 SCOTT 3000 RESEARCH
  11. 7839 KING 5000 ACCOUNTING
  12. 7844 TURNER 1500 SALES
  13. 7876 ADAMS 1100 RESEARCH
  14.  
  15. EMPNO ENAME SAL DNAME
  16. ---------- ---------- ---------- --------------
  17. 7900 JAMES 950 SALES
  18. 7902 FORD 3000 RESEARCH
  19. 7934 MILLER 1300 ACCOUNTING

sql> –不等值连接
sql> –查询员工信息:员工号 姓名 月薪 工资级别
sql> select * from salgrade;

  1. ***GRADE LOSAL HISAL

  1. 1 700 1200
  2. 2 1201 1400
  3. 3 1401 2000
  4. 4 2001 3000
  5. 5 3001 9999***

sql> select e.empno,s.grade
2 from emp e,salgrade s
3 where e.sal between s.losal and s.hisal;

  1. ***EMPNO ENAME SAL GRADE

  1. 7369 SMITH 800 1
  2. 7900 JAMES 950 1
  3. 7876 ADAMS 1100 1
  4. 7521 WARD 1250 2
  5. 7654 MARTIN 1250 2
  6. 7934 MILLER 1300 2
  7. 7844 TURNER 1500 3
  8. 7499 ALLEN 1600 3
  9. 7782 CLARK 2450 4
  10. 7698 BLAKE 2850 4
  11. 7566 JONES 2975 4
  12. EMPNO ENAME SAL GRADE

  1. 7788 SCOTT 3000 4
  2. 7902 FORD 3000 4
  3. 7839 KING 5000 5***

sql> –外连接
sql> –按部门统计员工人数:部门号 部门名称 人数
sql> select d.deptno 部门号,d.dname 部门名称,count(e.empno) 人数
2 from emp e,dept d
3 where e.deptno=d.deptno
4 group by d.deptno,d.dname;

  1. ***部门号 部门名称 人数

  1. 10 ACCOUNTING 3
  2. 20 RESEARCH 5
  3. 30 SALES 6

sql> select * from dept;
DEPTNO DNAME LOC


  1. 10 ACCOUNTING NEW YORK
  2. 20 RESEARCH DALLAS
  3. 30 SALES CHICAGO
  4. 40 OPERATIONS BOSTON***

**sql> /
sql> 外连接:某些不成立的记录,通过外连接依然可以包含在最后的结果中
sql> 左外连接:当where e.deptno=d.deptno不成立的时候,等号左边的表任然包含在最后的结果中
sql> 写法:where e.deptno=d.deptno(+)
sql> 右外连接:当where e.deptno=d.deptno不成立的时候,等号右边的表任然包含在最后的结果中
sql> 写法: where e.deptno(+)=d.deptno
sql> /**

sql> select d.deptno 部门号,dept d
3 where e.deptno(+)=d.deptno
4 group by d.deptno,d.dname;

  1. 部门号 部门名称 人数
  2. ---------- -------------- ----------
  3. 10 ACCOUNTING 3
  4. 40 OPERATIONS 0
  5. 20 RESEARCH 5
  6. 30 SALES 6

sql> –自连接
sql> –查询员工信息: 员工的名字 老板的名字
sql> –自连接:通过表的别名,将同一张表视为多张表
sql> select e.ename 员工的名字,b.ename 老板名字
2 from emp e,emp b
3 where e.mgr=b.empno;

  1. 员工的名字 老板名字
  2. ---------- ----------
  3. FORD JONES
  4. SCOTT JONES
  5. JAMES BLAKE
  6. TURNER BLAKE
  7. MARTIN BLAKE
  8. WARD BLAKE
  9. ALLEN BLAKE
  10. MILLER CLARK
  11. ADAMS SCOTT
  12. CLARK KING
  13. BLAKE KING
  14.  
  15. 员工的名字 老板名字
  16. ---------- ----------
  17. JONES KING
  18. SMITH FORD

sql> –层次查询
sql> select level,empno,ename,mgr
2 from emp
3 connect by prior empno=mgr
4 start with mgr is null
5 order by 1;

  1. LEVEL EMPNO ENAME MGR
  2. ---------- ---------- ---------- ----------
  3. 1 7839 KING
  4. 2 7566 JONES 7839
  5. 2 7698 BLAKE 7839
  6. 2 7782 CLARK 7839
  7. 3 7902 FORD 7566
  8. 3 7521 WARD 7698
  9. 3 7900 JAMES 7698
  10. 3 7934 MILLER 7782
  11. 3 7499 ALLEN 7698
  12. 3 7788 SCOTT 7566
  13. 3 7654 MARTIN 7698
  14.  
  15. LEVEL EMPNO ENAME MGR
  16. ---------- ---------- ---------- ----------
  17. 3 7844 TURNER 7698
  18. 4 7876 ADAMS 7788
  19. 4 7369 SMITH 7902

更多可以参看

Oracle数据库总结:

Oracle数据库之集合运算
Oracle数据库之数据处理
Oracle数据库之建表和管理表
Oracle数据库之对象视图、索引、序列、同义词

猜你在找的Oracle相关文章