oracle 性能优化操作四:尽量去掉"IN"、"OR"

来源:互联网 发布:国家对于大数据发展 编辑:程序博客网 时间:2024/04/30 01:31

【本文转载自:http://blog.csdn.net/helloboat/article/details/42418131,对作者表示感谢。】


含有”IN”、”OR”的Where子句常会使用工作表,使索引失效;
如果不产生大量重复值,可以考虑把子句拆开;拆开的子句中应该包含索引。
例:

select count(*) from stuff where id_no in('0','1');--(23秒) 

可以考虑将or子句分开:

select count(*) from stuff where id_no='0';select count(*) from stuff where id_no='1';

然后再做一个简单的加法,与原来的SQL语句相比,查询速度更快。

0 0