【YashanDB 知识库】复合索引下 in 大量参数查询性能慢
本文内容来自 YashanDB 官网,原文内容请见https://www.yashandb.com/newsinfo/7802945.html?templateId=1718516
【标题】复合索引下 in 大量参数查询性能慢
【关键字】复合索引 in 大量参数
【问题描述】
测试表数据量 200w,表结构如图,且在 ID 和 PHONE 字段上创建了复合索引
测试 SQL 为:
复制代码
执行时间:
且使用 no_index_ffs 的 hint 也无法达到优化
【问题原因分析】
检查执行计划可知,计划中先 access ID>50000 的区域,再用 filter 去过滤 in 大量参数的场景,整体性能较差
【解决/规避方法】
先将原本的复合索引设为 invisible。
新建复合索引 IND_TEST1119_PHONE_ID,将需要用 in 大量过滤的字段放在复合索引的前面。
复制代码
检查执行计划,先 access 来过滤,复合预期
当前执行时间:
【影响范围】当前所有版本
【修复版本】-
版权声明: 本文为 InfoQ 作者【YashanDB】的原创文章。
原文链接:【http://xie.infoq.cn/article/6ea4e864ae3b5adf944d5471e】。文章转载请联系作者。
评论