all 、any 、some的使用

SQL> SELECT sal FROM scott.emp WHERE job='MANAGER';
 
      SAL
---------
  2975.00
  2850.00
  2450.00

any:

SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal>any(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------
 7839 KING       PRESIDENT   5000.00
 7902 FORD       ANALYST     3000.00
 7788 SCOTT      ANALYST     3000.00
 7566 JONES      MANAGER     2975.00
 7698 BLAKE      MANAGER     2850.00

对比我们可以发现  这个查询出的sal>2450 ,也即是说>any的意思是大于子查询的最最小的sal

SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal<any(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------
 7369 SMITH      CLERK        800.00
 7900 JAMES      CLERK        950.00
 7876 ADAMS      CLERK       1100.00
 7521 WARD       SALESMAN    1250.00
 7654 MARTIN     SALESMAN    1250.00
 7934 MILLER     CLERK       1300.00
 7844 TURNER     SALESMAN    1500.00
 7499 ALLEN      SALESMAN    1600.00
 7782 CLARK      MANAGER     2450.00
 7698 BLAKE      MANAGER     2850.00
 
10 rows selected

在和子查询的sal对比,可以看出sal<2950,sal<any ()意思是小于子查询中最大的sal

 

 

SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal=any(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------
 7566 JONES      MANAGER     2975.00
 7698 BLAKE      MANAGER     2850.00
 7782 CLARK      MANAGER     2450.00

从结果可以看出就是子查询

 

all:

SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal>ALL(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------
 7788 SCOTT      ANALYST     3000.00
 7902 FORD       ANALYST     3000.00
 7839 KING       PRESIDENT   5000.00

查询结果显示:sal>all()是大于子查询中最大的sal

SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal<ALL(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------
 7499 ALLEN      SALESMAN    1600.00
 7844 TURNER     SALESMAN    1500.00
 7934 MILLER     CLERK       1300.00
 7521 WARD       SALESMAN    1250.00
 7654 MARTIN     SALESMAN    1250.00
 7876 ADAMS      CLERK       1100.00
 7900 JAMES      CLERK        950.00
 7369 SMITH      CLERK        800.00
 
8 rows selected

查询结果显示:sal>all()是小于子查询中最小的sal

 SQL> SELECT emp.empno,emp.ename,emp.job,emp.sal FROM scott.emp  WHERE sal=all(SELECT sal FROM scott.emp WHERE job='MANAGER');
 
EMPNO ENAME      JOB             SAL
----- ---------- --------- ---------

 

 

some: some和any的用法一样 ,sal>some(sal) 大于子查询中最小的sal,sal<some(sal)小于子查询中最大的sal

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/* * 基于双向链表实现双端队列结构 */ package dsa; public class Deque_DLNode implements Deque { protected DLNode header;//指向头节点(哨兵) protected DLNode trailer;//指向尾节点(哨兵) protected int size;//队列中元素的数目 //构造函数 public Deque_DLNode() { header = new DLNode(); trailer = new DLNode(); header.setNext(trailer); trailer.setPrev(header); size = 0; } //返回队列中元素数目 public int getSize() { return size; } //判断队列是否为空 public boolean isEmpty() { return (0 == size) ? true : false; } //取首元素(但不删除) public Object first() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); return header.getNext().getElem(); } //取末元素(但不删除) public Object last() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); return trailer.getPrev().getElem(); } //在队列前端插入新节点 public void insertFirst(Object obj) { DLNode second = header.getNext(); DLNode first = new DLNode(obj, header, second); second.setPrev(first); header.setNext(first); size++; } //在队列后端插入新节点 public void insertLast(Object obj) { DLNode second = trailer.getPrev(); DLNode first = new DLNode(obj, second, trailer); second.setNext(first); trailer.setPrev(first); size++; } //删除首节点 public Object removeFirst() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); DLNode first = header.getNext(); DLNode second = first.getNext(); Object obj = first.getElem(); header.setNext(second); second.setPrev(header); size--; return(obj); } //删除末节点 public Object removeLast() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); DLNode first = trailer.getPrev(); DLNode second = first.getPrev(); Object obj = first.getElem(); trailer.setPrev(second); second.setNext(trailer); size--; return(obj); } //遍历 public void Traversal() { DLNode p = header.getNext(); while (p != trailer) { System.out.print(p.getElem()+" "); p = p.getNex
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值