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

相关推荐
malog_9 小时前
Milvus向量数据库:AI时代的搜索革命
数据库·人工智能·后端·milvus
胡耀超9 小时前
《设计数据密集型应用》(DDIA, 2nd ed.) 心智模型导览——《Designing Data-Intensive Applications》书介绍导航
大数据·数据库·分布式·ai·架构·数据
ai安歌9 小时前
鸿蒙PC:Qt适配OpenHarmony实战【人名录】:单机联系人卡片,不读系统通讯录也能演示详情联动
数据库·qt·harmonyos
夏贰四9 小时前
数据库管理有哪些核心要点?数据库管理该如何规范落地?
大数据·数据库·数据库管理·数据库管理员
彦为君10 小时前
JavaSE-11-ByteBuffer(NIO核心组件)
java·开发语言·前端·数据库·后端·spring·nio
2301_8035389510 小时前
数据分析中count函数怎么用更高效
数据库·oracle
YL2004042610 小时前
【Redis基础篇】Redis常见命令
数据库·redis·缓存
ZengLiangYi10 小时前
ChatCrystal大量对话导入时的内存优化
sql·ai编程
treacle田10 小时前
达梦数据库-收缩数据库表空间步骤及示例记录总结
数据库·达梦数据库收缩表空间
丷丩11 小时前
Postgresql基础实践教程(五)
数据库·postgresql