• Oracle子查询


    使用子查询解决问题

    • 谁的工资比 Abel 高?

    image-20210604164032965

    SELECT	select_list
    FROM	table
    WHERE	expr operator
    		 	(SELECT	select_list
    		        FROM		table);
    
    • 子查询 (内查询) 在主查询之前一次执行完成。

    • 子查询的结果被主查询(外查询)使用 。

    SELECT last_name
    FROM   employees
    WHERE  salary >
                   (SELECT salary
                    FROM   employees
                    WHERE  last_name = 'Abel');
    

    注意事项

    • 子查询要包含在括号内

    • 将子查询放在比较条件的右侧

    • 单行操作符对应单行子查询,多行操作符对应多行子查询。

    单行子查询

    • 只返回一行。

    • 使用单行比较操作符。

    操作符 含义
    = Equal to
    > Greater than
    >= Greater than or equal to
    < Less than
    <= Less than or equal to
    <> Not equal to

    执行单行子查询

    返回job_id与141号员工相同,salary比143号员工多的员工姓名,job_id 和工资

    SELECT last_name, job_id, salary
    FROM   employees
    WHERE  job_id =  
                    (SELECT job_id
                     FROM   employees
                     WHERE  employee_id = 141)
    AND    salary >
                    (SELECT salary
                     FROM   employees
                     WHERE  employee_id = 143);
    
    

    在子查询中使用组函数

    返回公司工资最少的员工的last_name,job_id和salary

    SELECT last_name, job_id, salary
    FROM   employees
    WHERE  salary = 
                    (SELECT MIN(salary)
                     FROM   employees);
    
    

    子查询中的 HAVING 子句

    • 首先执行子查询。

    • 向主查询中的HAVING 子句返回结果。

    查询最低工资大于50号部门最低工资的部门id和其最低工资

    SELECT   department_id, MIN(salary)
    FROM     employees
    GROUP BY department_id
    HAVING   MIN(salary) >
                           (SELECT MIN(salary)
                            FROM   employees
                            WHERE  department_id = 50);
    

    非法使用子查询

    SELECT employee_id, last_name
    FROM   employees
    WHERE  salary =
                    (SELECT   MIN(salary)
                     FROM     employees
                     GROUP BY department_id);
    
    ERROR at line 4:
    ORA-01427: single-row subquery returns more thanone row
    

    多行子查询使用单行比较符

    子查询中的空值问题

    SELECT last_name, job_id
    FROM   employees
    WHERE  job_id =
                    (SELECT job_id
                     FROM   employees
                     WHERE  last_name = 'Haas');
    

    子查询不返回任何行

    多行子查询

    • 返回多行。

    • 使用多行比较操作符。

    操作符 含义
    IN 等于列表中的任意一个
    ANY 和子查询返回的某一个值比较
    ALL 和子查询返回的所有值比较

    **在多行子查询中使用 ANY 操作符

    返回其它部门中比job_id为‘IT_PROG’部门任一工资低的员工的员

    工号、姓名、job_id 以及salary

    SELECT employee_id, last_name, job_id, salary
    FROM   employees
    WHERE  salary < ANY
                        (SELECT salary
                         FROM   employees
                         WHERE  job_id = 'IT_PROG')
    AND    job_id <> 'IT_PROG';
    

    在多行子查询中使用 ALL 操作符

    返回其它部门中比job_id为‘IT_PROG’部门所有工资都低的员工

    的员工号、姓名、job_id 以及salary

    SELECT employee_id, last_name, job_id, salary
    FROM   employees
    WHERE  salary < ALL
                        (SELECT salary
                         FROM   employees
                         WHERE  job_id = 'IT_PROG')
    AND    job_id <> 'IT_PROG';
    
    努力学习java的Cherish
  • 相关阅读:
    用数据泵技术实现逻辑备份Oracle 11g R2 数据泵技术详解(expdp impdp)
    用mysql实现类似于oracle dblink的功能
    统计1的个数
    转置字符串,其中单词内的字符需要正常
    经典排序之归并排序
    公共子序列与公共子串问题
    placement new (转)
    数组排序组合最小数字
    实现两个数相加不用四则运算
    操作系统中作业、线程、进程、内存管理、垃圾回收以及缓存等概念
  • 原文地址:https://www.cnblogs.com/cherish-code/p/14850394.html
Copyright © 2020-2023  润新知