在Oracle的子查询中使用some,any和all

php中文网
发布: 2016-06-07 17:03:02
原创
1315人浏览过

用some,any和all对子查询中返回的多行结果进行处理。下面我们来简单介一下这几个关键词的含义。Some在此表示满足其中一个的意义,

some,anyall对子查询中返回的多行结果进行处理。下面我们来简单介一下这几个关键词的含义。

  • Some在此表示满足其中一个的意义,是用or串起来的比较从句。
  • Any

    推荐阅读:Oracle函数取得姓名对应的拼音

    下面是一些例子
    找出员工中,只要比部门号为10的员工中的任何一个员工的工资高的员工的姓名个工资。也就是说只要比部门号为10的员工中的那个工资最少的员工的工资高就满足条件。

    select ename,sal
    From emp
    Where sal > any(select sal from emp where deptno = 10);

    这里推荐用any,如果你非要用some也是没有任何问题的,结果是一样的,只是一般来讲some用在“=”的比较从句中。
    select ename,sal
    From emp
    Where sal > some(select sal from emp where deptno = 10);

    上面的用法完全OK的。
    select ename,sal
    From emp
    Where sal = some(select sal from emp where deptno = 30) and deptno not in (select deptno from emp where deptno = 30);

    上面才是some的正常用法。其含义是找到和30部门员工的任何一个人工资相同的那些员工。虽然没有找到。
    最后一个关键字all的用法也很简单就是要与子查询的每一结果都要匹配。

    Veo
    Veo

    Google 最新发布的 AI 视频生成模型

    Veo 567
    查看详情 Veo

    select ename,sal
    From emp
    Where sal > all(select sal from emp where deptno = 20);

    上面的SQL语句的意义与前面的就完全不一样了,其意义是找到比部门号为20的员工的所有员工的工资都要高的员工,,也就是比那个工资最高的员工的还要高的员工总的来说someany用法意义是一样的,仅在词法上有不同,都表示对子查询结果集中的比较关系,而all则是对子查询结果集总每一个结果的关系 

    举几个例子来说明ALL和ANY的用法
    1. SELECT * FROM TABLEA WHERE FLD > ALL(SELECT FLD FROM TABLEA)
    这相当于
    SELECT * FROM TABLEA WHERE FLD > (SELECT MAX(FLD) FROM TABLEA)

    2. SELECT * FROM TABLEA WHERE FLD 这相当于
    SELECT * FROM TABLEA WHERE FLD 

    3. SELECT * FROM TABLEA WHERE FLD = ANY(SELECT FLD FROM TABLEA)
    这相当于
    SELECT * FROM TABLEA WHERE FLD IN (SELECT FLD FROM TABLEA)

    linux

  • 最佳 Windows 性能的顶级免费优化软件
    最佳 Windows 性能的顶级免费优化软件

    每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

    下载
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号