0

0

SQL范围查询如何走索引_BETWEEN使用注意事项【教程】

舞姬之光

舞姬之光

发布时间:2025-12-24 20:05:02

|

577人浏览过

|

来源于php中文网

原创

BETWEEN能否走索引取决于字段是否有有效索引、数据类型是否匹配、边界值是否为SARG;需满足最左前缀原则、避免隐式转换、使用确定性表达式。

sql范围查询如何走索引_between使用注意事项【教程】

SQL中使用 BETWEEN 进行范围查询时,**能否走索引不取决于BETWEEN本身,而取决于字段是否建立了有效索引、数据类型是否匹配、以及边界值是否可被优化器识别为SARG(Search Argument)**。用对了,它和 >= AND 效果一致;用错了,可能全表扫描。

字段必须有合适的索引

只有在查询字段上建立了单列索引或复合索引的最左前缀列,BETWEEN才可能命中索引。

  • 例如:SELECT * FROM orders WHERE order_date BETWEEN '2024-01-01' AND '2024-12-31'; —— 要走索引,order_date 列必须有索引(如 INDEX idx_date (order_date)
  • 若用的是复合索引 INDEX idx_user_date (user_id, order_date),则 WHERE order_date BETWEEN ... 单独使用无法走该索引(违反最左前缀原则)
  • WHERE user_id = 123 AND order_date BETWEEN ... 就可以充分利用该复合索引

数据类型要严格匹配,避免隐式转换

隐式类型转换是索引失效的高发区。BETWEEN两边的值类型必须与字段类型一致。

  • 字段是 DATETIME,但写成 BETWEEN '2024-01-01' AND '2024-12-31'(无时分秒)—— 多数数据库仍能走索引,但MySQL 5.7+对严格模式更敏感;稳妥做法是补全时间:'2024-01-01 00:00:00' AND '2024-12-31 23:59:59'
  • 字段是 INT,却传入字符串:WHERE id BETWEEN '100' AND '200' → 可能触发隐式转换,导致索引失效
  • 字符型字段用BETWEEN要注意排序规则(collation),比如大小写敏感字段上查 BETWEEN 'a' AND 'z',结果可能不符合预期,且不一定走索引

边界值需确定、非动态表达式

数据库优化器需要在执行计划生成阶段就能评估范围,因此BETWEEN的左右操作数应是常量或参数化变量,不能是函数或子查询。

Vozo
Vozo

Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。

下载
  • ✅ 支持索引:WHERE create_time BETWEEN ? AND ?(预编译参数)、BETWEEN '2024-01-01' AND DATE_ADD('2024-01-01', INTERVAL 30 DAY)(MySQL中部分版本可推导)
  • ❌ 很可能不走索引:WHERE create_time BETWEEN NOW() - INTERVAL 7 DAY AND NOW()(某些旧版本MySQL无法在计划阶段固化范围)
  • ❌ 索引失效:WHERE name BETWEEN UPPER('abc') AND LOWER('XYZ') —— 函数作用于边界值,破坏SARG性

注意BETWEEN是闭区间,逻辑等价于 >= AND

这是基础但易错的一点:BETWEEN包含两端值。如果业务本意是“过去7天”(不含今天),写成 BETWEEN DATE_SUB(CURDATE(), INTERVAL 6 DAY) AND CURDATE() 就会多出一天。

  • 推荐更清晰写法:create_time >= '2024-01-01' AND create_time (左闭右开),尤其适合时间字段,避免因秒级精度或时区导致漏/重数据
  • 对于整数主键分页等场景,BETWEEN更简洁;但对于时间、字符串等易受精度/排序影响的类型,显式写出 >= 和

不复杂但容易忽略。核心就三点:有索引、类型对、边界稳。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

673

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

344

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1081

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

355

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

671

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

561

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

404

2024.04.29

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 769人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号