Oracle数据库总结:

Oracle数据库之基本查询
Oracle数据库之过滤和排序
Oracle数据库之单行函数
Oracle数据库之多行函数
Oracle数据库之多表查询

SQL> 注意的问题:

SQL> 1. 括号
SQL> 2. 合理的书写风格
SQL> 3. 可以在主查询的where select having from后面都可以放置子查询
SQL> 4. 不可以在group by放置子查询
SQL> 5. 强调from后面的子查询
SQL> 6. 主查询和子查询可以不是同一张表;只要子查询返回的结果主查询可以使用即可
SQL> 7. 一般不在子查询排序;但在top-n分析问题中,必须对子查询排序
SQL> 8. 一般先执行子查询,再执行主查询;但相关子查询例外
SQL> 9. 单行子查询只能使用单行操作符;多行子查询只能使用多行操作符
SQL> 10. 子查询中的null

SQL> --查询工资比SCOTT高的员工信息

SQL> select *
2 from emp
3 where sal > (select sal
4 from emp
5 where ename=‘SCOTT’);

  EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7839 KING       PRESIDENT            17-11月-81           5000                    10

SQL> --3. 可以在主查询的where select having from后面都可以放置子查询

SQL> select empno,ename,sal,(select job from emp where empno=7839) 第四列
2 from emp;

     EMPNO ENAME             SAL 第四列
---------- ---------- ---------- ---------                                                                                                                                                              7369 SMITH             800 PRESIDENT                                                                                                                                                              7499 ALLEN            1600 PRESIDENT                                                                                                                                                              7521 WARD             1250 PRESIDENT                                                                                                                                                              7566 JONES            2975 PRESIDENT                                                                                                                                                              7654 MARTIN           1250 PRESIDENT                                                                                                                                                              7698 BLAKE            2850 PRESIDENT                                                                                                                                                              7782 CLARK            2450 PRESIDENT                                                                                                                                                              7788 SCOTT            3000 PRESIDENT                                                                                                                                                              7839 KING             5000 PRESIDENT                                                                                                                                                              7844 TURNER           1500 PRESIDENT                                                                                                                                                              7876 ADAMS            1100 PRESIDENT                                                                                                                                                              EMPNO ENAME             SAL 第四列
---------- ---------- ---------- ---------                                                                                                                                                              7900 JAMES             950 PRESIDENT                                                                                                                                                              7902 FORD             3000 PRESIDENT                                                                                                                                                              7934 MILLER           1300 PRESIDENT

SQL> --5. 强调from后面的子查询

SQL> --查询员工信息:员工号 姓名 月薪
SQL> select *
2 from (select empno,ename,sal from emp);

   EMPNO ENAME             SAL
---------- ---------- ----------                                                                                                                                                                        7369 SMITH             800                                                                                                                                                                        7499 ALLEN            1600                                                                                                                                                                        7521 WARD             1250                                                                                                                                                                        7566 JONES            2975                                                                                                                                                                        7654 MARTIN           1250                                                                                                                                                                        7698 BLAKE            2850                                                                                                                                                                        7782 CLARK            2450                                                                                                                                                                        7788 SCOTT            3000                                                                                                                                                                        7839 KING             5000                                                                                                                                                                        7844 TURNER           1500                                                                                                                                                                        7876 ADAMS            1100                                                                                                                                                                        EMPNO ENAME             SAL
---------- ---------- ----------                                                                                                                                                                        7900 JAMES             950                                                                                                                                                                        7902 FORD             3000                                                                                                                                                                        7934 MILLER           1300

SQL> --6. 主查询和子查询可以不是同一张表;只要子查询返回的结果主查询可以使用即可

SQL> --查询部门名称是SALES的员工信息
SQL> select *
2 from emp
3 where deptno=(select deptno
4 from dept
5 where dname=‘SALES’);

  EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30                                                                                                              7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30                                                                                                              7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400         30                                                                                                              7698 BLAKE      MANAGER         7839 01-5月 -81           2850                    30                                                                                                              7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30                                                                                                              7900 JAMES      CLERK           7698 03-12月-81            950                    30

SQL> select e.*
2 from emp e,dept d
3 where e.deptno=d.deptno and d.dname=‘SALES’;

    EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30                                                                                                              7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30                                                                                                              7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400         30                                                                                                              7698 BLAKE      MANAGER         7839 01-5月 -81           2850                    30                                                                                                              7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30                                                                                                              7900 JAMES      CLERK           7698 03-12月-81            950                    30

SQL> --in 在集合中

SQL> --查询部门名称是SALES和ACCOUNTING的员工
1 select *
2 from emp
3* where deptno in (select deptno from dept where dname=‘SALES’ or dname=‘ACCOUNTING’)

  EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30                                                                                                              7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30                                                                                                              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                                                                                                              7839 KING       PRESIDENT            17-11月-81           5000                    10                                                                                                              7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30                                                                                                              7900 JAMES      CLERK           7698 03-12月-81            950                    30                                                                                                              7934 MILLER     CLERK           7782 23-1月 -82           1300                    10                                                                                                              已选择 9 行。

SQL> --any: 和集合中任意一个值比较

SQL> --查询工资比30号部门任意一个员工高的员工信息
SQL> select *
2 from emp
3 where sal > any (select sal from emp where deptno=30);

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

1 select *
2 from emp
3* where sal > (select min(sal) from emp where deptno=30)

  EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              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 19-4月 -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 23-5月 -87           1100                    20                                                                                                              7902 FORD       ANALYST         7566 03-12月-81           3000                    20                                                                                                              EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7934 MILLER     CLERK           7782 23-1月 -82           1300                    10                                                                                                              已选择 12 行。

SQL> --all: 和集合中的所有值比较

SQL> --查询工资比30号部门所有员工高的员工信息
SQL> select *
2 from emp
3 where sal > all (select sal from emp where deptno=30);

     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7566 JONES      MANAGER         7839 02-4月 -81           2975                    20                                                                                                              7788 SCOTT      ANALYST         7566 19-4月 -87           3000                    20                                                                                                              7839 KING       PRESIDENT            17-11月-81           5000                    10                                                                                                              7902 FORD       ANALYST         7566 03-12月-81           3000                    20

1 select *
2 from emp
3* where sal > (select max(sal) from emp where deptno=30)

     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7566 JONES      MANAGER         7839 02-4月 -81           2975                    20                                                                                                              7788 SCOTT      ANALYST         7566 19-4月 -87           3000                    20                                                                                                              7839 KING       PRESIDENT            17-11月-81           5000                    10                                                                                                              7902 FORD       ANALYST         7566 03-12月-81           3000                    20

SQL> --多行子查询中的null

SQL> --查询不是老板的员工

SQL> select *
2 from emp
3 where empno not in (select mgr from emp);

未选定行

SQL> --查询是老板的员工
1 select *
2 from emp
3* where empno in (select mgr from emp)
SQL> /

   EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7902 FORD       ANALYST         7566 03-12月-81           3000                    20                                                                                                              7698 BLAKE      MANAGER         7839 01-5月 -81           2850                    30                                                                                                              7839 KING       PRESIDENT            17-11月-81           5000                    10                                                                                                              7566 JONES      MANAGER         7839 02-4月 -81           2975                    20                                                                                                              7788 SCOTT      ANALYST         7566 19-4月 -87           3000                    20                                                                                                              7782 CLARK      MANAGER         7839 09-6月 -81           2450                    10

SQL> select *
2 from emp
3 where empno not in (select mgr from emp where mgr is not null);

  EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM     DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ---------- ----------                                                                                                              7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0         30                                                                                                              7521 WARD       SALESMAN        7698 22-2月 -81           1250        500         30                                                                                                              7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400         30                                                                                                              7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300         30                                                                                                              7934 MILLER     CLERK           7782 23-1月 -82           1300                    10                                                                                                              7369 SMITH      CLERK           7902 17-12月-80            800                    20                                                                                                              7876 ADAMS      CLERK           7788 23-5月 -87           1100                    20                                                                                                              7900 JAMES      CLERK           7698 03-12月-81            950                    30

Oracle数据库总结:

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

Oracle数据库之子查询相关推荐

  1. Oracle数据库:子查询、单行子查询,多行子查询,in,any,all语句,子查询的练习案例

    Oracle数据库:子查询.单行子查询,多行子查询,in,any,all语句,子查询的练习案例 2022找工作是学历.能力和运气的超强结合体,遇到寒冬,大厂不招人,可能很多算法学生都得去找开发,测开 ...

  2. Oracle数据库多重子查询嵌套的坑

    在Oracle数据库中多重子查询的使用 代码如下: SELECT T.*, ROWNUM RNFROM (SELECT B.*,NVL(A.AMOUNT, 0) AMOUNT,V.FULLNAME,D ...

  3. Oracle 数据库的子查询(关联子查询)

    文章目录 一.子查询结果返回一个值(单列单行) 二.子查询结果返回多行(单列多行) 三.子查询结果返回多列多行 四.关联子查询 (一)子查询执行顺序 (二)exists 关键字 五.子查询总结 六.关 ...

  4. 查看oracle数据库启动状态,Oracle数据库的状态查询

    1 状态查询 启动状态 SQL语句 结果 nomount select status from v$instance; STARTED select open_mode from v$database ...

  5. oracle 游标查询数据库,Oracle数据库使用游标查询结果集所有数据

    --Oracle使用游标查询结果集所有数据 DECLARE myTabelName NVARCHAR2(200):=''; --表名 myTableRowComment NVARCHAR2(200): ...

  6. Oracle数据库日期范围查询的两种实现方式

    Oracle数据库日期范围查询有两种方式:to_char方式和to_date方式,接下来我们通过一个实例来介绍这一过程.我们假设要查询2011-05-02到2011-05-30之间的数据,实现方式如下 ...

  7. Oracle数据库之基本查询

    oracle安装参照: Oracle数据库之安装教程 Oracle数据库总结: Oracle数据库之基本查询 Oracle数据库之过滤和排序 Oracle数据库之单行函数 Oracle数据库之多行函数 ...

  8. oracle数据库元数据SQL查询

    oracle数据库经典SQL查询 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size fro ...

  9. Oracle数据库Date类型查询问题(

    浅谈Oracle数据库Date类型查询问题 用过Oracle数据库的朋友应该知道,Oracle数据库在以Date类型为查询条件时存在一个小小的BUG,如: select * from tableNam ...

最新文章

  1. vue监听h5页面返回健(微信和支付宝浏览器亲测):
  2. python基础学习(二)注释和算术运算符
  3. CLOSE_WAIT?项目上线之际遇到这样的烦心事
  4. 修改显卡型号软件_马甲显卡又双叕来了 怎么选知道吗?
  5. Java 中的位移运算符
  6. P4016 负载平衡问题
  7. Android MVP 框架
  8. Django中的核心思想ORM---元类实现ORM
  9. PHP基础班初学感悟
  10. Java进阶 创建和销毁对象
  11. [转]编译器选项(摘自MSDN)及VC项目配置基础
  12. linux之dos2unix命令
  13. 当SEO/SEM与良知正面碰撞
  14. 每一个写博客的程序猿,都应该被温柔对待
  15. 面试时如何做自我介绍?聪明的应聘者只聚焦1点
  16. MES工程师新手,该怎么学习?学习哪些技术?
  17. 智能手机网页制作12个注意事项
  18. iphone11pro市场价_iPhone11 Pro Max:再见
  19. mac mini 蓝牙_Mac Mini
  20. 求命题公式的真值表及主范式(栈实现)

热门文章

  1. VS2017-VC++校验和计算小工具
  2. STM32系统时钟默认设置
  3. python 语言教程(3)变量之列表(List)
  4. C++ Primer 5th笔记(chap 18 大型程序工具) using指示
  5. 数学建模——智能优化之粒子群模型详解Python代码
  6. 【django】配置MySQL数据库【3】
  7. [mmu/cache]-ARMV8的cache的维护指令介绍
  8. [ARM异常]-图解armv7/armv8的异常向量表和基地址
  9. 【网络安全】反序列化漏洞底层扩展与制作WebShell
  10. MySql 查询小数保留两位小数