EXISTS和IN的区别
来源:互联网 发布:手游源码一般多少钱 编辑:程序博客网 时间:2024/06/08 13:34
这是我以前参与过的一个项目的经验,SQL(这只是一个示意语句)语句如下
update A cd
set cd. FLAG='0001', cd.DATE = sysdate
where exists(
select 1
from (
select tc.dno,tc.gno
from B tc,C ad
where tc.GNO = ad.DNO
and ad.DNO = 'sssssssssssssssss'
) a
where a.dno = cd.dno
and a.gno = cd.gno
)
这条语句的基本功能就是两张表中的数据,查找到一条符合条件的数据,并根据这条数据的ID,修改第三张表里面的某些值,但是这三张表都是百万级的数据记录,在使用这条语句的时候,根据客户反应,大概需要20几分钟,才能正常完成,这是用户无法接受的。
我们仔细分析的SQL语句,发现使用的关键字是EXISTS,而exists是对外表作loop,每次loop再对那表进行查询,这样,多次进行大表查询,难免会变慢,再考虑一下功能相似IN关键字,IN是对表进行HASH JOIN,比较适合内外表都比较大的情形,而EXISTS适合外表比较小的情形,经过分析,大家一致通过修改为IN操作,修改后的语句如下:
update A cd
set cd.FLAG='0001',DATE = sysdate
where (dno,gno) in
(
select tc.dno,tc.gno
from B tc,C ad
where tc.GNO = ad.DNO
and ad.DECL_NO = ‘ssssssssssss’
)
修改之后,客户反映性能大大提升,现在数据量没变,但是完成相同的功能,却只需要1分钟不到的时间。
综上所述,IN 和 EXISTS都是有自己的适用环境的,并不存在哪个关键字优于哪一个的情况,同时,也要求我们在具体使用的时候,要选择适合自己需要的情况使用。
- exists 和 in 的区别
- exists 和 in 的区别
- Exists和In的区别
- EXISTS和IN的区别
- exists 和in 的区别
- exists 和 in 的区别
- in 和 exists的区别
- in和exists的区别
- in和exists的区别
- in和exists的区别
- in 和exists 的区别
- EXISTS和IN的区别
- IN 和EXISTS的区别
- exists和in的区别和优化
- in 和 exists 区别
- IN和EXISTS区别
- in 和 exists区别
- in 和 exists区别
- bzoj1579 [Usaco2009 Feb]Revamping Trails 道路升级(分层图最短路)
- Spark1.6.3学习02——Spark Programming Guide
- BZOJ 3262: 陌上花开 CDQ
- python类与对象part3
- Linux 实用记录
- EXISTS和IN的区别
- Linux之百度云服务器搭建
- ROWNUM的用法
- N*N矩阵
- 利用索引优化的步骤
- 蓝牙学知识三【connEventCounter】【Attribute Data List】
- 解决导入过程中出现的ORA-02289错误
- 1059. C语言竞赛(20)
- POJ