news 2026/4/16 7:21:42

SQL 中 BETWEEN 和 IN 的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQL 中 BETWEEN 和 IN 的区别

一、BETWEEN 详细说明

1.1 用法

BETWEEN ... AND ...用于判断某个字段的值是否在一段“连续区间”之内(包括区间的起点和终点)。

1.2 适用的数据类型

  • 数值类型(如 int, float)
  • 日期或时间类型(如 date, datetime, timestamp)
  • 字符串类型(会依据排序的字典序)

1.3 例子

1.3.1 数值
SELECT*FROMordersWHEREtotal_priceBETWEEN100AND200;

含义:所有 total_price 大于等于 100 且小于等于 200 的订单。

1.3.2 日期
SELECT*FROMordersWHEREorder_dateBETWEEN'2024-01-01'AND'2024-01-31';

含义:所有下单日期在 1 月 1 日到 1 月 31 日之间的订单。

1.3.3 字符串
SELECT*FROMusersWHEREusernameBETWEEN'aaa'AND'mmm';

含义:用户名在 ‘aaa’ 到 ‘mmm’ 字典序之间的用户。

1.4 注意事项

  • 包括边界值,即等价于column >= a AND column <= b
  • 如果a > b,结果可能为空或行为依赖于数据库实现。
  • 对字符串来说,排序由数据库字符集决定,不常用于字符串筛选。

1.5 不能乱用的场景

  • 非连续的多值筛选(如只要A、B、C,不要A到C之间全部),不适用。

二、IN 详细说明

2.1 用法

IN (value1, value2, ... valueN)用于判断某个字段是否等于给定的若干个具体值(离散集合)。

2.2 适用的数据类型

  • 数值
  • 字符串
  • 日期/时间
  • 甚至支持子查询

2.3 例子

2.3.1 数值集合
SELECT*FROMemployeesWHEREdepartment_idIN(1,2,5,8);

含义:部门号为1、2、5、8的员工。

2.3.2 字符串集合
SELECT*FROMstudentsWHEREnameIN('Alice','Bob','Cathy');

含义:名字是 Alice、Bob 或 Cathy 的学生。

2.3.3 子查询
SELECT*FROMordersWHEREcustomer_idIN(SELECTidFROMcustomersWHEREvip=1);

含义:下单人是 “VIP 客户” 的订单。

2.4 注意事项

  • IN里面的值,可以是任何类型,只要和字段类型对应即可。
  • 当集合内值较多时,内部会自动优化(但上千个值效率一般不如临时表)。
  • NOT IN表示“不在这些值”。
  • IN的筛选是**“任意一个匹配即可”**。

2.5 不能乱用的场景

  • 区间判断(如 2 到 10 之间所有整数),不用IN,应用BETWEEN

三、扩展对比表

使用场景推荐用法代码示例
连续区间查找BETWEEN ... AND ...score BETWEEN 80 AND 100
离散多个值查找IN (...)city IN ('Beijing', 'Shanghai', 'Guangzhou')
排除某集合NOT IN (...)user_id NOT IN (123, 456, 789)
区间筛选排除不推荐用 IN,有风险应使用区间条件price < 100 OR price > 200
子集判断IN (子查询)product_id IN (SELECT id FROM products WHERE ...)

四、举例说明区别

  1. 查找出生日期是 2000 年 1 月 1 日至 2000 年 12 月 31 日内的员工

    • 推荐BETWEEN
    SELECT*FROMemployeesWHEREbirthdayBETWEEN'2000-01-01'AND'2000-12-31';
  2. 查找部门在 1、3、5号的员工

    • IN
    SELECT*FROMemployeesWHEREdepartment_idIN(1,3,5);
  3. 错误用法举例

    -- 错误,用 BETWEEN 查离散值,等价于 BETWEEN 1 AND 5,会返回 2、3、4 都被查出SELECT*FROMemployeesWHEREdepartment_idBETWEEN1AND5;

    实际只要 1、3、5应该用

    SELECT*FROMemployeesWHEREdepartment_idIN(1,3,5);

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 0:06:11

运动康复AI分析方案:从安装到出结果仅需10分钟

运动康复AI分析方案&#xff1a;从安装到出结果仅需10分钟 引言&#xff1a;当康复师遇上AI助手 作为一名从业10年的康复治疗师&#xff0c;我深知动作评估的重要性。每次看到患者因疼痛而扭曲的动作&#xff0c;都恨不得有双"透视眼"能精确量化每个关节的角度变化…

作者头像 李华
网站建设 2026/4/15 10:37:48

Web版骨骼点演示:Flask+ONNX预装镜像,10分钟上线Demo

Web版骨骼点演示&#xff1a;FlaskONNX预装镜像&#xff0c;10分钟上线Demo 引言&#xff1a;为什么选择这个方案&#xff1f; 作为一名前端工程师&#xff0c;你可能经常遇到这样的困境&#xff1a;面试时需要展示AI项目&#xff0c;但后端部署和模型推理部分总是让人头疼。…

作者头像 李华
网站建设 2026/4/14 0:17:59

Z-Image API快速集成:ComfyUI云端REST服务搭建

Z-Image API快速集成&#xff1a;ComfyUI云端REST服务搭建 引言 作为一名开发者&#xff0c;你是否遇到过这样的困境&#xff1a;想要在自己的APP中集成强大的AI图像生成功能&#xff0c;却被复杂的模型部署、GPU资源管理和API开发搞得焦头烂额&#xff1f;Z-Image作为阿里开…

作者头像 李华
网站建设 2026/4/12 14:54:34

MediaPipe Hands技术指南:手部姿态估计原理与实践

MediaPipe Hands技术指南&#xff1a;手部姿态估计原理与实践 1. 引言&#xff1a;AI 手势识别与追踪的现实意义 随着人机交互技术的不断演进&#xff0c;手势识别正逐步成为智能设备、虚拟现实&#xff08;VR&#xff09;、增强现实&#xff08;AR&#xff09;和智能家居等场…

作者头像 李华
网站建设 2026/4/1 20:14:32

Z-Image-Turbo量化版实测:云端6G显存也能跑,成本直降80%

Z-Image-Turbo量化版实测&#xff1a;云端6G显存也能跑&#xff0c;成本直降80% 1. 为什么你需要Z-Image-Turbo量化版 作为一名自媒体博主&#xff0c;你可能经常遇到这样的困境&#xff1a;想批量生成高质量配图&#xff0c;但家用电脑的显卡性能不足&#xff0c;生成一张图…

作者头像 李华
网站建设 2026/4/3 5:51:00

AI手势识别与追踪文档解读:官方库集成避坑指南

AI手势识别与追踪文档解读&#xff1a;官方库集成避坑指南 1. 引言&#xff1a;AI 手势识别与追踪的现实价值 随着人机交互技术的不断演进&#xff0c;非接触式控制正逐步从科幻走向现实。在智能设备、虚拟现实&#xff08;VR&#xff09;、增强现实&#xff08;AR&#xff09…

作者头像 李华