oracle中使用in 和 not in 查询效率分析

devtools/2025/2/3 4:50:52/

在Oracle数据库中,INNOT IN的查询效率受多种因素影响,以下是关键点总结和优化建议:


1. IN 的效率

  • 优化方式
    • IN 通常会被优化为 OR条件半连接(Semi-Join),如果子查询关联到外部表,可能转为 EXISTS
    • 若字段有索引,且优化器选择索引扫描(Index Scan),效率较高。
  • 适用场景
    • 静态值列表较短时(例如 IN (1,2,3))。
    • 子查询结果集较小且能利用索引时。

2. NOT IN 的潜在问题

  • NULL 值陷阱
    如果子查询结果包含 NULLNOT IN 会导致结果集为空(逻辑上等价于 != ALL)。需确保子查询字段非空(如添加 WHERE col IS NOT NULL)。
  • 效率问题
    • 若子查询结果集较大,NOT IN 可能需要全表扫描,效率较低。
    • 可能被优化为 反连接(Anti-Join),但需索引支持。
  • 替代方案
    优先使用 NOT EXISTS,避免 NULL 问题且通常更高效(尤其在子查询能利用索引时)。

3. 优化建议

  • 使用 EXISTS/NOT EXISTS 替代

    -- 优于 NOT IN
    SELECT * FROM table1 t1 
    WHERE NOT EXISTS (SELECT 1 FROM table2 t2 WHERE t2.id = t1.id
    );
    
    • EXISTS 在找到匹配项后立即终止子查询,减少计算量。
    • NULL 安全,无需额外处理。
  • 确保索引有效

    • IN/NOT IN 涉及的字段创建索引(尤其是主键或高选择性字段)。
    • 子查询的连接字段(如 t2.id)应建立索引。
  • 处理长静态列表

    • 避免超过1000个元素的静态列表(如 IN (1,2,...,1001)),可改用临时表或拆分查询。
  • 检查执行计划
    使用 EXPLAIN PLAN 分析查询是否走索引或优化为高效的连接方式(如哈希反连接)。


4. 示例对比

场景:查询在表B中不存在的记录
  • 低效写法(可能受NULL影响):
    SELECT * FROM tableA 
    WHERE id NOT IN (SELECT id FROM tableB);
    
  • 高效改写
    SELECT * FROM tableA a 
    WHERE NOT EXISTS (SELECT 1 FROM tableB b WHERE b.id = a.id
    );
    

5. 关键总结

操作符效率影响因素适用场景注意事项
IN索引、子查询结果集大小、静态列表长度小结果集或静态短列表避免超长静态列表
NOT IN子查询中的NULL、索引缺失、结果集大小需显式处理NULL的子查询优先用 NOT EXISTS 替代
EXISTS子查询索引、关联字段检查存在性,尤其是大表关联NULL 安全
NOT EXISTS子查询索引、关联字段检查不存在性,替代 NOT IN优于 NOT IN 的通用选择

通过合理使用索引、避免 NULL 陷阱、改写为 EXISTS/NOT EXISTS,并结合执行计划分析,可以显著提升查询效率。


http://www.ppmy.cn/devtools/155631.html

相关文章

Github 2025-02-01 开源项目月报 Top20

根据Github Trendings的统计,本月(2025-02-01统计)共有20个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目8TypeScript项目3Jupyter Notebook项目2Rust项目2HTML项目2C++项目1Ruby项目1JavaScript项目1Svelte项目1非开发语言项目1Go项目1Oll…

猿人学web 19题(js逆向)

这题直接点击翻页抓包,然后获取seesion ID请求即可 求和代码 import requestssession requests.Session() cookies {sessionid:eao9i00r8pt4xu6uzzx2k01ttqn51yc9} urlhttps://match.yuanrenxue.cn/api/match/19?page sum0 for i in range(1,6):response sess…

DeepSeek大模型技术深度解析:揭开Transformer架构的神秘面纱

摘要 DeepSeek大模型由北京深度求索人工智能基础技术研究有限公司开发,基于Transformer架构,具备卓越的自然语言理解和生成能力。该模型能够高效处理智能对话、文本生成和语义理解等复杂任务,标志着人工智能在自然语言处理领域的重大进展。 关…

高低频混合组网系统中基于地理位置信息的信道测量算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a 3.部分核心程序 (完整版代码包含详细中文注释和操作步骤视频&#xff09…

vue中的el是指什么

简介: 在Vue.js中,el指的是Vue实例的挂载元素。 具体来说,el是一个选项,用于指定Vue实例应该挂载到哪个DOM元素上。通过这个选项,Vue可以知道应该从哪个元素开始进行模板编译和渲染。它可以是一个CSS选择器字符串&…

5分钟带你获取deepseek api并搭建简易问答应用

目录 1、获取api 2、获取base_url和chat_model 3、配置模型参数 方法一:终端中临时将加入 方法二:创建.env文件 4、 配置client 5、利用deepseek大模型实现简易问答 deepseek-v3是截止博文撰写之日,无论是国内还是国际上发布的大模型中…

Manacher 最长回文子串

方法&#xff1a;求字符串的 #include<bits/stdc.h> using namespace std; using lllong long; const int N1e69; char s[N]; int p[N];int main() {cin>>s1;int nstrlen(s1);s[0]^;s[2*n2]$; for(int i2*n1;i>1;i--){s[i](i&1)?#:s[i>>1];//右移表示…

衡水市城区小区地图)矢量高清cdr|pdf大图内容测评

&#xff08;衡水市城区小区地图&#xff09;矢量高清cdr|pdf大图&#xff0c;cdr。ai软件打开另保存cdr&#xff0c;ai格式就可以&#xff0c;看样图