设为首页 加入收藏

TOP

Oracle学习(五):多表查询(一)
2015-07-24 10:38:55 来源: 作者: 【 】 浏览:1
Tags:Oracle 学习 查询

1.知识点:可以对照下面的录屏进行阅读

SQL> --等值连接
SQL> --查询员工信息: 员工号 姓名 月薪  部门名称
SQL> select empno,ename,sal,dname
  2  from emp,dept
  3  where emp.deptno=dept.deptno;

SQL> --不等值连接
SQL> --查询员工信息: 姓名 月薪  工资级别
SQL> select ename,sal,grade
  2  from emp e,salgrade s
  3  where e.sal between s.losal and s.hisal;

SQL> --外连接
SQL> -- 外连接解决的问题:当条件不成立时,任然希望在结果中包含不成立的记录
SQL> -- 左外连接: where d.deptno=e.deptno 当不成立时,等号左边代表的表的信息任然被包含
SQL> --         写法: where d.deptno=e.deptno(+)
SQL> -- 右外连接: where d.deptno=e.deptno 当不成立时,等号右边代表的表的信息任然被包含
SQL> --         写法:where d.deptno(+)=e.deptno
SQL> --按部门统计员工人数: 部门号  部门名称  人数
SQL> --错误的列子:没有员工的部门,没有显示
SQL> select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno
  4  group by d.deptno,d.dname;
SQL> --上面这个例子改正版:使用了左外连接
SQL> select d.deptno,d.dname,count(e.empno)
  2  from dept d,emp e
  3  where d.deptno=e.deptno(+)
  4  group by d.deptno,d.dname;

SQL> --自连接
SQL> --查询员工信息:***的老板是***
SQL> select e.ename||'的老板是'||b.ename
  2  from emp e,emp b
  3  where e.mgr=b.empno;
SQL> --核心:利用表的别名,将同一张表视为多张表

SQL> --使用层次查询的原因:自连接不太适合操作大表
SQL> --层次查询:对同一张表的前后两次操作,进行连接
SQL> --层次查询:遍历一棵树
SQL> select level,empno,ename,mgr	--level:伪列,Oracle自动加上的列,在层次查询中表示节点的深度
  2  from emp
  3  connect by prior empno=mgr	--连接条件:上一次查询的empno = 下一次查询的mgr
  4  start with mgr is null	--从根开始遍历整个树(在这个例子中,根即为老板号为空)
  5  order by 1;

2.在Sqlplus下实际执行的结果录屏:

SQL> host cls

SQL> --等值连接
SQL> --查询员工信息: 员工号 姓名 月薪  部门名称
SQL> desc dept
 名称                                                                                是否为空? 类型
 ----------------------------------------------------------------------------------- -------- --------------------------------------------------------
 DEPTNO                                                                              NOT NULL NUMBER(2)
 DNAME                                                                                        VARCHAR2(14)
 LOC                                                                                          VARCHAR2(13)

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

     EMPNO ENAME        SAL DNAME                                                                                                                     
---------- ---------- ----- --------------                                                                                                            
      7369 SMITH        800 RESEARCH                                                                                                                  
      7499 ALLEN       1600 SALES                                                                                                                     
      7521 WARD        1250 SALES                                                                                                                     
      7566 JONES       2975 RESEARCH                                                                                                                  
      7654 MARTIN      1250 SALES                                                                                                                     
      7698 BLAKE       2850 SALES                                                                                                                     
      7782 CLARK       2450 ACCOUNTING                                                                                                                
      7788 SCOTT       3000 RESEARCH                                                                                                                  
      7839 KING        5000 ACCOUNTING                                                                                                                
      7844 TURNER      1500 SALES                                                                                                                     
      7876 ADAMS       1100 RESEARCH                                                                                                                  

     EMPNO ENAME        SAL DNAME                                                                                                                     
---------- ---------- ----- --------------                                                                                                            
      7900 JAMES        950 SALES                                                                                                                     
      7902 FORD        3000 RESEARCH                                                                                                                  
      7934 MILLER      1300 ACCOUNTING                                                                                                                

已选择14行。

SQL> ed
已写入 file afiedt.buf

  1  select empno,ename,sal,dname
  2  from emp e,dept d
  3* where e.deptno=d.deptno
SQL> /

     EMPNO ENAME        SAL DNAME                                                                                                                     
---------- ---------- ----- --------------                                                                                                            
      7369 SMITH        800 RESEARCH                                                                                                                  
      7499 ALLEN       1600 SALES                                                                                                                     
      7521 WARD        1250 SALES                                                                                                                     
      7566 JONES       2975 RESEARCH                                                                                                                  
      7654 MARTIN      1250 SALES                                                                                                                     
      7698 BLAKE       2850 SALES                                                                                                                     
      7782 CLARK       2450 ACCOUNTING                                                                                                                
      7788 SCOTT       3000 RESEARCH                                                                                                                  
      7839 KING        5000 ACCOUNTING                                                                                                                
      7844 TURNER      1500 SALES                                                                                                                     
      7876 ADAMS       1100 RESEARCH                                                                                                                  

     EMPNO ENAME        SAL DNAME                                                                                                                     
---------- ---------- ----- --------------                                                                                                            
      7900 JAMES        950 SALES                                                                                                                     
      7902 FORD        3000 RESEARCH                                                                                                                  
      7934 MILLER      1300 ACCOUNTING                                                                                                                

已选择14行。

SQL> host cls

SQL> --不等值连接
SQL> --查询员工信息: 姓名 月薪  工资级别
SQL> select * from tab;

TNAME                          TABTYPE  CLUSTERID                                                                                                     
------------------------------ ------- ----------                                                                                                     
DEPT                           TABLE                                                                                                                  
EMP                            TABLE                                                                                                                  
BONUS                          TABLE                                                                                                                  
SALGRADE                       TABLE                                                                                                                  

SQL> select * from salgrade;

     GRADE      LOSAL      HISAL                                                                                                                      
---------- ---------- ----------                                                                                                                      
         1        700       1200                                                                                                                      
         2       1201       1400                                                                                                                      
         3       1401       2000                                                                                                                      
         4       2001       3000                                                                                                                      
         5       3001       9999                                                                                                                      

SQL> select ename,sal,grade
  2  from emp e,salgrade s
  3  wh
首页 上一页 1 2 3 下一页 尾页 1/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇RMAN的"rman: can't ope.. 下一篇oracle case when exists()

评论

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

·请问c语言刚入门,该 (2025-12-26 10:21:04)
·python 编程怎么定义 (2025-12-26 10:21:01)
·09-指 针 (一)-c语言 (2025-12-26 10:20:58)
·About - Redis (2025-12-26 08:20:56)
·Redis: A Comprehens (2025-12-26 08:20:53)