zoukankan      html  css  js  c++  java
  • 子查询及exists

    子查询分为无关子查询和相关子查询

    无关子查询,只查询一次,与外查询无关,可作为查询条件:

    select * from student where sno in (select sno from student where class = 98789);
    

      也可作为一个虚拟表使用。

    相关子查询,查询多次,依赖外部查询:

    select * from student  where exists (select * from Student);--只要存在条件满足,就查询
    

    在这里引申出一个exists,它和in的区别是:

    使用EXISTS,Oracle会首先检查主查询,然后运行子查询直到它找到第一个匹配项,这就节省了时间。Oracle在执行IN子查询时,首先执行子查询,并将获得的结果列表存放在一个加了索引的临时表中。在执行子查询之前,系统先将主查询挂起,待子查询执行完毕,存放在临时表中以后再执行主查询。这也就是使用EXISTS比使用IN通常查询速度快的原因

    (转自 http://blog.sina.com.cn/s/blog_601d1ce30100cyrb.html)

  • 相关阅读:
    hdu5514 非2的次幂容斥原理
    「NOIP2015」斗地主
    「NOIP2009」靶形数独
    「CF521D」Shop
    「HNOI2015」菜肴制作
    「NOIP2011」观光公交
    「NOI2015」荷马史诗
    「JSOI2007」建筑抢修
    「CF161B」Discounts
    叠罗汉
  • 原文地址:https://www.cnblogs.com/whytohow/p/4914731.html
Copyright © 2011-2022 走看看