news 2026/4/18 8:54:58

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/18 8:29:01

智能零售实践:顾客动线分析基于骨骼关键点

智能零售实践&#xff1a;顾客动线分析基于骨骼关键点 引言 在零售行业&#xff0c;了解顾客在店内的行为模式是优化商品陈列和提升销售的关键。传统方法依赖人工观察或外包视频标注&#xff0c;不仅成本高昂&#xff08;单个视频标注费用可达数百元&#xff09;&#xff0c;…

作者头像 李华
网站建设 2026/4/18 5:28:04

Z-Image-ComfyUI傻瓜式教程:3分钟出图不求人

Z-Image-ComfyUI傻瓜式教程&#xff1a;3分钟出图不求人 引言&#xff1a;宝妈也能轻松上手的AI绘画神器 作为一名白天带娃、晚上挤时间学习的宝妈&#xff0c;你可能经常遇到这样的困扰&#xff1a;想给孩子制作专属绘本插图&#xff0c;却苦于没有绘画基础&#xff1b;想学…

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

多人姿态估计避坑指南:云端分布式推理,成本降60%

多人姿态估计避坑指南&#xff1a;云端分布式推理&#xff0c;成本降60% 1. 什么是多人姿态估计&#xff1f; 多人姿态估计&#xff08;Multi-Person Pose Estimation&#xff09;是计算机视觉中的一项关键技术&#xff0c;它能够同时检测图像或视频中多个人体的关键点位置。…

作者头像 李华
网站建设 2026/4/18 10:07:52

小白也能懂!Qwen2.5-0.5B-Instruct保姆级网页推理教程

小白也能懂&#xff01;Qwen2.5-0.5B-Instruct保姆级网页推理教程 1. 引言&#xff1a;为什么选择 Qwen2.5-0.5B-Instruct&#xff1f; 在大语言模型&#xff08;LLM&#xff09;快速发展的今天&#xff0c;阿里云推出的 Qwen2.5 系列 成为了开源社区中备受关注的明星模型。其…

作者头像 李华
网站建设 2026/4/18 10:06:29

AI绘画成本对比:Z-Image云端方案vs买显卡,省下万元

AI绘画成本对比&#xff1a;Z-Image云端方案vs买显卡&#xff0c;省下万元 1. 引言&#xff1a;美术工作室的AI绘画成本困境 最近两年&#xff0c;AI绘画技术突飞猛进&#xff0c;Z-Image等模型已经能生成专业级的插画和设计稿。但对于中小型美术工作室来说&#xff0c;面临一…

作者头像 李华
网站建设 2026/4/18 8:06:48

开源AI手势识别模型发展:MediaPipe Hands实战指南

开源AI手势识别模型发展&#xff1a;MediaPipe Hands实战指南 1. 引言&#xff1a;人机交互的新范式——AI手势识别与追踪 在智能硬件、虚拟现实&#xff08;VR&#xff09;、增强现实&#xff08;AR&#xff09;和人机交互&#xff08;HCI&#xff09;快速发展的今天&#x…

作者头像 李华