SQL 中 BETWEEN 和 IN 的区别


一、BETWEEN 详细说明

1.1 用法

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

1.2 适用的数据类型

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

1.3 例子

1.3.1 数值
sql 复制代码
SELECT * FROM orders WHERE total_price BETWEEN 100 AND 200;

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

1.3.2 日期
sql 复制代码
SELECT * FROM orders WHERE order_date BETWEEN '2024-01-01' AND '2024-01-31';

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

1.3.3 字符串
sql 复制代码
SELECT * FROM users WHERE username BETWEEN '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 数值集合
sql 复制代码
SELECT * FROM employees WHERE department_id IN (1, 2, 5, 8);

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

2.3.2 字符串集合
sql 复制代码
SELECT * FROM students WHERE name IN ('Alice', 'Bob', 'Cathy');

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

2.3.3 子查询
sql 复制代码
SELECT * FROM orders WHERE customer_id IN (SELECT id FROM customers WHERE vip = 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
    sql 复制代码
    SELECT * FROM employees WHERE birthday BETWEEN '2000-01-01' AND '2000-12-31';
  2. 查找部门在 1、3、5号的员工

    • IN
    sql 复制代码
    SELECT * FROM employees WHERE department_id IN (1, 3, 5);
  3. 错误用法举例

    sql 复制代码
    -- 错误,用 BETWEEN 查离散值,等价于 BETWEEN 1 AND 5,会返回 2、3、4 都被查出
    SELECT * FROM employees WHERE department_id BETWEEN 1 AND 5;

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

    sql 复制代码
    SELECT * FROM employees WHERE department_id IN (1, 3, 5);

相关推荐
xiaowu0807 分钟前
C# 拆解 “显式接口实现 + 子类强类型扩展” 的设计思想
数据库·oracle
讯方洋哥21 分钟前
HarmonyOS App开发——关系型数据库应用App开发
数据库·harmonyos
惊讶的猫1 小时前
Redis持久化介绍
数据库·redis·缓存
Apple_羊先森1 小时前
ORACLE数据库巡检SQL脚本--19、磁盘读次数最高的前5条SQL语句
数据库·sql·oracle
全栈前端老曹2 小时前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
神梦流2 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
让学习成为一种生活方式2 小时前
trf v4.09.1 安装与使用--生信工具42-version2
数据库
啦啦啦_99992 小时前
Redis-5-doFormatAsync()方法
数据库·redis·c#
生产队队长2 小时前
Redis:Windows环境安装Redis,并将 Redis 进程注册为服务
数据库·redis·缓存
老邓计算机毕设2 小时前
SSM找学互助系统52568(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 毕业设计