当前位置: 首页 > news >正文

in 子查询 or in 子查询改写

1、 问题语句

select t1.c1,t1.c2,t1.c3 from t1 where(t1.gid in(select gid from t2 where d1 ='C2')or t1.gid in(select gid from t3 where e1 ='C2'))and(t1.c1 ='C4'or t1.c1 is null)and(t1.c2 liketrim('D4%')or t1.c3 liketrim('E7%'));

计划:

这里的in子查询+or+in子查询做成表达式,无法先过滤,这里in子查询里面的条件过滤性较好,可以利用索引先过滤,之前的文章中有提过or条件可以改写成union all,这里可以考虑改写成union all。

2、改写

select t1.c1,t1.c2,t1.c3 from t1 where(t1.gid in(select gid from t2 where d1 ='C2'union all select gid from t3 where e1 ='C2'))and(nvl(t1.c1,'C4')='C4')and(t1.c2 liketrim('D4%')or t1.c3 liketrim('E7%'));

计划:

这里能够很好的利用索引先过滤,这里能够很好的利用索引先过滤,另外in也可以改写成exists,于是这个改写又有另一种改写方法

select t1.c1,t1.c2,t1.c3 from t1 where exists(select 1 from(select gid from t2 where d1 ='C2'union all select gid from t3 where e1 ='C2')A where t1.gid = A.gid)and(nvl(t1.c1,'C4')='C4')and(t1.c2 liketrim('D4%')or t1.c3 liketrim('E7%'));

计划:

两种改写方法计划一致,性能都提升几十倍。

3、小结

or条件过滤性很好就比较适合做union all,这个例子也是对前面or关联案例的补充。

http://www.cnnetsun.cn/news/173411.html

相关文章:

  • 从宕机到自愈:Open-AutoGLM自动恢复系统的7个核心技术组件
  • Open-AutoGLM电影票购买实战指南(99%人不知道的隐藏技巧)
  • 【稀缺资料】Open-AutoGLM企业级实战FAQ:仅限内部流传的7条黄金法则曝光
  • 数据安全合规迫在眉睫,Open-AutoGLM加密优化方案已让500+企业脱敏升级
  • Redis到底支不支持事务啊?
  • 从文本到视频只需1分钟?Open-AutoGLM自动化生成实测揭秘
  • Open-AutoGLM推理延迟高?:4种优化路径+实测数据对比,立竿见影降本30%
  • 你真的会导出AutoGLM配置吗?:8个必须掌握的操作要点一次讲清
  • Excalidraw移动端体验如何?iOS/Android使用评测
  • 好写作AI:论文结论被批“太水”?你可能需要这个“灵魂拷问”AI
  • 【Open-AutoGLM性能革命】:解锁高并发文本输入的3大关键技术
  • 【AI系统高可用性保障】:基于Open-AutoGLM的3层故障恢复架构设计
  • 【Open-AutoGLM数据安全优化指南】:揭秘本地加密存储性能提升的5大核心技术
  • 【Open-AutoGLM失败恢复核心技术】:揭秘企业级数据保护的5大关键策略
  • Python数据结构(下):字典、集合及综合练习
  • AI+科学发现:从药物分子到新材料,加速科研进程
  • Open-AutoGLM控件状态精准识别实战(工业级UI自动化新突破)
  • FCKEditor支持Word图片上传转存保留图文混排结构
  • 无需设计功底!Excalidraw让你秒变架构图绘画高手
  • Excalidraw如何导出高清图片?避免模糊的三大要点
  • 组织结构图数据批量导入 快速生成工具
  • Excalidraw图形伦理审查标记
  • 【反自动化检测终极武器】:Open-AutoGLM如何绕过行为风控系统?
  • 大同市软件公司哪个口碑好
  • 为什么你的Open-AutoGLM总是超时?重试次数设置不当正在拖垮性能
  • Open-AutoGLM权限管理难题终结者,企业级共享架构设计全揭秘
  • 大数据领域数据架构的自动化运维模式
  • 揭秘Open-AutoGLM多手指同步机制:从延迟优化到事件分发的底层逻辑
  • Open-AutoGLM文本生成提速全攻略(内部优化模型首次公开)
  • 从零构建控件识别系统,基于Open-AutoGLM的自动化测试进阶之路