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);

相关推荐
产幻少年2 小时前
redis位图
数据库·redis·缓存
驾数者3 小时前
Flink SQL容错机制:Checkpoint与Savepoint实战解析
大数据·sql·flink
短剑重铸之日3 小时前
《7天学会Redis》Day 4 - 高可用架构设计与实践
数据库·redis·缓存
NineData3 小时前
第三届数据库编程大赛-八强决赛成绩揭晓
数据库·算法·代码规范
難釋懷4 小时前
认识Redis
数据库·redis·缓存
超级种码4 小时前
Redis:Redis脚本
数据库·redis·缓存
想唱rap4 小时前
表的约束条件
linux·数据库·mysql·ubuntu·bash
超级种码4 小时前
Redis:Redis 命令详解
数据库·redis·bootstrap
qq_401700414 小时前
Qt 事件处理机制
java·数据库·qt