exists的学习初体验

今天在学习公司业务的时候,看到了程序中使用的exists关键字,这个关键字是数据库中的,在大学的时候,我就没有很好地理解这个关键字,到现在还是不太理解,总是觉得没有in关键字好用。
现在看到这个关键字我觉得很是胆怯啊,这次是我去读程序,而不是写程序了。不能够用in关键字去替代exists了,没办法我只好硬着头皮网上冲了。
我首先在网上看了看exists的相关用法和优点,看完之后才发现在有些时候exists的效率要比in关键字的效率高很多。
exists关键字主要适用于带有子查询的查询语句中,是这样的,如果主查询的数据量比子查询的数据量要大很多,这种情况下不建议使用exists关键字,取而代之的应该是in关键字;相反如果主查询的数据量比子查询的数据量要下很多,这种情况下就建议使用exists关键字了,而且效率会提高很多。
具体的例子在网上有很多,我下面就贴一个网上现成的例子:
1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ;

T1数据量小而T2数据量非常大时,T1<<T2 时,1) 的查询效率高。

2) select * from T1 where T1.a in (select T2.a from T2) ;

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

exists 用法:

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

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

“select 1 from T1,T2 where T1.a=T2.a”
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值