0

0

SQL查询中如何排除某些ID 主键排除的常见SQL写法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-06-21 16:48:02

|

672人浏览过

|

来源于php中文网

原创

sql查询中排除某些id的方法有多种,常见的包括:1.使用not in(子查询);2.not in(值列表);3.left join...where is null;4.not exists;5.except或minus。性能方面,not in适用于数据量小的情况,但对null值敏感;not exists通常性能更优;left join在索引有效时效率高。动态id可通过参数化查询、临时表或存储过程处理。主键和索引能显著提升性能,但大数据量时可能失效,需根据具体情况优化。

SQL查询中如何排除某些ID 主键排除的常见SQL写法

SQL查询中排除某些ID,其实就是告诉你,你要找的不是全部,而是“除了这些家伙之外”的那些。方法挺多的,关键看你的具体场景和SQL功底。

SQL查询中如何排除某些ID 主键排除的常见SQL写法
-- 方法1:使用 NOT IN (子查询)
SELECT *
FROM your_table
WHERE id NOT IN (SELECT id FROM table_with_ids_to_exclude);

-- 方法2:使用 NOT IN (值列表)
SELECT *
FROM your_table
WHERE id NOT IN (1, 2, 3, 4, 5);

-- 方法3:使用 LEFT JOIN ... WHERE IS NULL
SELECT t1.*
FROM your_table t1
LEFT JOIN table_with_ids_to_exclude t2 ON t1.id = t2.id
WHERE t2.id IS NULL;

-- 方法4:使用 NOT EXISTS
SELECT *
FROM your_table t1
WHERE NOT EXISTS (SELECT 1 FROM table_with_ids_to_exclude t2 WHERE t1.id = t2.id);

-- 方法5:如果数据库支持,可以使用 EXCEPT (或者 MINUS)
SELECT id FROM your_table
EXCEPT
SELECT id FROM table_with_ids_to_exclude;

SQL查询中NOT IN、NOT EXISTS、LEFT JOIN 的性能差异?

SQL查询中如何排除某些ID 主键排除的常见SQL写法

这三个方法,性能上各有千秋,不能一概而论哪个最好。一般来说:

SQL查询中如何排除某些ID 主键排除的常见SQL写法
  • NOT IN:如果table_with_ids_to_exclude数据量小,NOT IN性能还可以。但如果这个子查询返回的数据量很大,NOT IN 可能会导致全表扫描,性能急剧下降。而且,如果子查询结果中包含NULL,整个NOT IN 语句可能会返回空结果,需要注意处理NULL值。

  • NOT EXISTS:通常情况下,NOT EXISTS 的性能比 NOT IN 好,尤其是在子查询返回大量数据时。数据库优化器更容易优化 NOT EXISTS 语句。

  • LEFT JOIN ... WHERE IS NULL:在某些情况下,LEFT JOIN 的性能可能会更好,特别是当数据库能有效地使用索引时。但是,如果JOIN的条件不合适,也可能导致性能问题。

所以,最佳实践是:根据你的具体数据量、索引情况和数据库类型,分别测试这三种方法,选择性能最好的一个。实际操作中,explain一下查询计划看看,能给你更直观的答案。

如何处理排除的ID列表动态变化的情况?

Getimg.ai
Getimg.ai

getimg.ai是一套神奇的ai工具。生成大规模的原始图像

下载

如果排除的ID列表不是固定的,而是动态变化的,比如来自应用程序的参数,可以考虑以下几种方法:

  1. 动态构建SQL语句:在应用程序中,根据传入的ID列表,动态构建包含 NOT IN (id1, id2, ...) 的SQL语句。这种方法简单直接,但要注意SQL注入的风险,务必使用参数化查询。

  2. 使用临时表:将排除的ID列表插入到一个临时表中,然后在SQL查询中使用 NOT IN (SELECT id FROM temp_table) 或者 LEFT JOIN ... WHERE IS NULL 来排除这些ID。这种方法适用于ID列表比较大的情况。

    -- 创建临时表 (MySQL)
    CREATE TEMPORARY TABLE temp_exclude_ids (id INT);
    
    -- 插入排除的ID
    INSERT INTO temp_exclude_ids (id) VALUES (1), (2), (3);
    
    -- 使用临时表进行查询
    SELECT *
    FROM your_table
    WHERE id NOT IN (SELECT id FROM temp_exclude_ids);
    
    -- 删除临时表
    DROP TEMPORARY TABLE temp_exclude_ids;
  3. 使用存储过程:将排除ID的逻辑封装到存储过程中,在存储过程中动态构建SQL语句或者使用临时表。这种方法可以提高代码的可维护性和安全性。

主键排除时,索引对性能的影响?

如果id字段是主键,那么通常情况下数据库会自动为主键创建索引。使用这些方法进行排除查询时,索引可以大大提高查询性能。

  • NOT IN:如果id字段上有索引,数据库可以使用索引来快速定位不在排除列表中的记录。
  • NOT EXISTS:同样,索引可以帮助数据库优化器更有效地执行NOT EXISTS查询。
  • LEFT JOIN ... WHERE IS NULL:如果JOIN的条件字段上有索引,数据库可以使用索引来加速JOIN操作。

但是,如果排除的ID列表非常大,导致需要排除的记录数量过多,数据库可能会选择不使用索引,而进行全表扫描。这时候,可以考虑优化查询语句,或者调整数据库的索引策略。

还有一点,如果表的数据量非常小,即使没有索引,全表扫描的性能也可能比使用索引更好。所以,最终的性能取决于你的具体数据和查询情况。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

727

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

327

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1242

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

360

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

820

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

423

2024.04.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号