oracle中 exists 与 in效率及其用法

oracle中 exists 与 in效率及其用法

用not exists 代替not in

* from tsp_product p where not exists(select ” from tsp_orderitem i where p.id=i.product_id)select * from tsp_product p where id not in(select product_id from tsp_orderitem i where p.id=i.product_id)用exists 代替inselect * from tsp_product p where p.id  in(select product_id from tsp_orderitem )select * from tsp_product p where  exists(select ‘x’ from tsp_orderitem i where p.id =i.product_id )

下面来分析为什么用用not exists 代替not in

有两个简单例子,以说明 “exists”和“in”的效率问题

1) select * from t1 where exists(select 1 from t2 where t1.a=t2.a) ;

    t1数据量小而t2数据量非常大时,t1

2) select * from t1 where t1.a in (select t2.a from t2) ;

     t1数据量非常大而t2数据量小时,t1>>t2 时,2) 的查询效率高。

 

union
把两张表的数据合起来,如有重复行,只取一行
union all
把两张表的数据合起来,不过滤重复行
minus
返回在第一个查询结果中与第二个查询结果不相同的那部分行记录。 

oracle有这样的一些约定
1.select语句必须返回相同的列数,如果列数不同的话,可以选择串代替列。
2.select语句中相应的列必须有相同的数据类型,长度可以不同

rollup

统计:select sum(s.totalamount),to_char(createdate,’yyyy-mm’) from tsp_orders s group by rollup(to_char(createdate,’yyyy-mm’)

connect by
select level,a. * from tsp_area a start with parent_id is null connect by prior id = parent_id

说明:创建类似树报表。
 prior 强制报表的顺序变为从根到叶(如果prior是父辈)或从叶到根(如果prior是后代)
 虽然where子句可以人树排除上体,但无法排除他们的子孙子(或者祖先,如果prior在等号的右边)

详细看看它他的区别

exists 用法:

请注意 1)句中的有颜色字体的部分 ,理解其含义;

其中 “select 1 from t2 where t1.a=t2.a” 相当于一个关联表查询,相当于

“select 1 from t1,t2     where t1.a=t2.a”

但是,如果你当当执行 1) 句括号里的语句,是会报语法错误的,这也是使用exists需要注意的地方。

“exists(xxx)”就表示括号里的语句能不能查出记录,它要查的记录是否存在。

因此“select 1”这里的 “1”其实是无关紧要的,换成“*”也没问题,它只在乎括号里的数据能不能查找出来,是否存在这样的记录,如果存在,这 1) 句的where 条件成立。

in 的用法:

继续引用上面的例子

“2) select * from t1 where t1.a in (select t2.a from t2) ”

这里的“in”后面括号里的语句搜索出来的字段的内容一定要相对应,一般来说,t1和t2这两个表的a字段表达的意义应该是一样的,否则这样查没什么意义。

打个比方:t1,t2表都有一个字段,表示工单号,但是t1表示工单号的字段名叫“ticketid”,t2则为“id”,但是其表达的意义是一样的,而且数据格式也是一样的。这时,用 2)的写法就可以这样:

“select * from t1 where t1.ticketid in (select t2.id from t2) ”

select name from employee where name not in (select name from student);

select name from employee where not exists (select name from student);

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1839715.html

(0)
上一篇 2025年2月21日 23:08:58
下一篇 2025年2月21日 23:09:13

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 深入探讨 Laravel 集合的 Where 方法

    Laravel 是一款流行的 PHP 开发框架,它提供了许多实用的功能和工具,其中集合(Collection)是 Laravel 中一个非常强大且常用的工具之一。在集合中,Where 方法是一个非常有用的方法,可以让我们根据指定条件过滤集合…

    2025年5月2日
    000
  • Laravel 集合中的 Where 方法用法解析

    Laravel 是一款流行的 PHP 开发框架,它提供了丰富且便捷的功能,其中集合(Collection)是 Laravel 中非常重要的数据结构之一。集合类提供了许多强大的方法,其中一个常用的方法是 where 方法。本文将通过具体的代码…

    2025年5月2日
    000
  • Laravel 集合的 Where 方法详解

    Laravel 是一款流行的 PHP 框架,其集合(Collections)类提供了强大的数据处理功能。其中,Where 方法是集合类中常用的方法之一,用于筛选符合条件的数据。本文将详细介绍 Laravel 集合的 Where 方法,包括使…

    2025年5月2日
    000
  • Laravel 集合中的 Where 方法实用指南

    Laravel 集合中的 Where 方法实用指南 在Laravel框架的开发过程中,集合(Collection)是一个非常有用的数据结构,它提供了丰富的方法来操作数据。其中,Where方法是一个常用的筛选方法,能够根据指定条件来过滤集合中…

    2025年5月2日
    000
  • Laravel中where方法的常见错误及解决方法

    Laravel中where方法的常见错误及解决方法 在使用Laravel框架进行开发的过程中,我们经常会使用到Eloquent ORM来操作数据库。其中,where方法是一个非常常用的方法,用于筛选数据库中的数据。然而,由于对Laravel…

    2025年5月2日
    000
  • Laravel 集合中如何使用 Where 方法

    Laravel 集合中如何使用 Where 方法 Laravel 是一个流行的 PHP 框架,它提供了丰富的功能和工具,方便开发者快速构建应用程序。其中,集合(Collection)是 Laravel 中一个非常实用和强大的数据结构,开发者…

    2025年5月2日
    000
  • 深入解析Bootstrap中的下拉列表select

    本篇文章给大家详细介绍一下bootstrap中的下拉列表select,适合初学者学习,希望对大家有所帮助! 前言: 本人是多年Android开发,从0开始学习web前端。同样发现很多博客基本都是拷贝和复制,还说的不清楚。所以把我觉得目前博客…

    2025年5月1日
    000
  • 深入探讨 Laravel 集合的 Where 方法

    Laravel 是一款流行的 PHP 开发框架,它提供了许多实用的功能和工具,其中集合(Collection)是 Laravel 中一个非常强大且常用的工具之一。在集合中,Where 方法是一个非常有用的方法,可以让我们根据指定条件过滤集合…

    2025年4月2日
    300
  • Laravel 集合中的 Where 方法用法解析

    Laravel 是一款流行的 PHP 开发框架,它提供了丰富且便捷的功能,其中集合(Collection)是 Laravel 中非常重要的数据结构之一。集合类提供了许多强大的方法,其中一个常用的方法是 where 方法。本文将通过具体的代码…

    2025年4月2日
    200
  • Laravel 集合的 Where 方法详解

    Laravel 是一款流行的 PHP 框架,其集合(Collections)类提供了强大的数据处理功能。其中,Where 方法是集合类中常用的方法之一,用于筛选符合条件的数据。本文将详细介绍 Laravel 集合的 Where 方法,包括使…

    2025年4月2日
    100

发表回复

登录后才能评论