Oracle复合索引与空值的索引使用问题小结
网络编程 2021-07-05 16:09www.168986.cn编程入门
最近长沙网络推广在群里讨论sql优化的问题,今天长沙网络推广给大家带来了Oracle复合索引与空值的索引使用问题小结,需要的朋友参考下吧
昨天在QQ群里讨论一个SQL优化的问题,语句大致如下
select A,min(B) from table group by A;--A,B都没有not null约束,A列无空值,B列有空值。--存在复合索引IX_TEST(A,B)
于是手动测试,环境采用Oracle自带的scott用户下的emp表。
1.查看如下语句的执行计划(此时表只有主键索引)
2.添加IX_TEST(deptno,m)后查看执行计划
发现依然是全表扫描。
3.为deptno列添加非空约束后查看执行计划
4.
Btree索引是不存储空值的,这个是所有使用Btree索引的数据库的共同点。
在本例中我们创建了deptno,m的符合索引。如果deptno没有非空约束,那么说明有的record不会出现在索引中,此时想要找到min(m)就必须回表才能确定deptno为null的行是否有m的值。此时优化器认为全表扫描比扫描索引再回表更为合理,选择全表扫描。
当我们添加了非空约束后,deptno不可能为空,索引的key值数等于表总行数,另一列m即便为空也不影响min()取值,只需要扫描索引即可得到所需结果,此时优化器选择索引扫描。
而在Mysql中无论复合索引首列是否存在非空约束,都会使用索引,deptno为null的会全部分在一组取min(m),可能是Mysql的BTREE索引与Oracle的有所不同,使得首列为空都可以无需回表。
Oracle的列能添加非空约束的一定要添加。
以上所述是长沙网络推广给大家介绍的Oracle复合索引与空值的索引使用问题小结,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南