Oracle数据库之子查询

2023-12-15 10:18
文章标签 oracle 查询 数据库 之子

本文主要是介绍Oracle数据库之子查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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数据库之子查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/496090

相关文章

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA