兴国资源网 Design By www.nnzcdc.com
前言
在有一些情况下,开发同学经常使用like去实现一些业务需求,当使用like时,我们都知道使用like 前%(like ‘%111')这种情况是无法使用索引的,那么如何优化此类的SQL呢,下面是一个案例。
原SQL如下:
pcc_cust_infonew 表索引如下
执行设计如下:
这里可以看到SQL执行3.96秒,执行计划中也可以发现PCC_CUST_INFONEW表走TABLE ACCESS FULL扫描,返回约380k的数据,然后再与PCC_CUST_CONTRACTCOMPANY表主键PK_PCC_CUST_CONTRACTCOMPANY走INDEX UNIQUE SCAN,这里慢主要是执行计划中为3的这一步。
我们也都知道在Oracle中,当使用like时,如果是后%(like ‘138%')是可以使用索引的,如果是前%(like ‘%138')是无法正常使用索引。那么如何让前%也可以使用到索引呢,答案是可以使用reverse索引的形式进行优化。
优化如下:
修改索引
将SQL调整为
按以上调整后,SQL执行效率提升到毫秒级。
调整后的执行计划如下:
那使用reverse函数索引后,到底是如何做到可以使用索引了呢,当你看到执行计划下面的谓词信息想必你就知道答案了,
其实就是使用reverse函数索引将索引数据反转,SQL中的where条件中将值反转,这样就将前%改为后%。
总结
以上就是关于使用reverse索引优化like语句的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
兴国资源网 Design By www.nnzcdc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
兴国资源网 Design By www.nnzcdc.com
暂无评论...
更新日志
2024年04月29日
2024年04月29日
- dnf无尽的祭坛怎么去
- 网易雷火宣布《魔兽世界》国服开启测试招募报名!
- 游侠晚报:《剑星》遭和谐引众怒!《沙漠大冒险》好评
- 《蟹蟹寻宝奇遇》首日售出3万份 类魂游戏也能很可爱
- 谢玲玲.2010-丽风金点系列2CD【珍藏版】【WAV+CUE】
- 叶佩雯.2001-SHINE【英皇娱乐】【FLAC分轨】
- 胡鸿钧.2023-我们在结束时开始新曲+精丫TVBMUSIC】【WAV+CUE】
- 曝NS2具备完全向后兼容性!硬件只是一次保守升级
- 小松菜奈产子后首次亮相:新片《我们是谁》发布会
- 因电脑显示屏位置没放对 25岁女孩差点臂“瘫”
- 张敬轩.2014-MORPH【英皇娱乐】【WAV+CUE】
- 群星.2024-惜花芷影视原声带【D-JINMUSIC】【FLAC分轨】
- 李国祥.2011-循环再唱(K2HD限量版)【新世纪】【WAV+CUE】
- 【原神】枫丹V4.6世界任务 | 终章·安魂曲+++后续隐藏任务
- 【原神】V4.6角色攻略 | 选仆人还是林尼?优缺点对比