-
SQL之between and查询日期时的边界问题
- 网站名称:SQL之between and查询日期时的边界问题
- 网站分类:技术文章
- 收录时间:2025-06-08 15:51
- 网站地址:
“SQL之between and查询日期时的边界问题” 网站介绍
问题描述
都知道between and查询是包含上下边界的, 但是在遇到
形如
select 字段1, 字段2 from table_xxx where 时间字段 between 开始时间 and 结束时间
的日期查询时, 查询结果可能会出乎意料.
(注意: 使用的数据库是MariaDB(MySQL), 时间字段 是 DATETIME 类型)
比如: select 字段1, 字段2 from table_xxx where 时间字段 between '2021-05-01' and '2021-05-10' 的查询结果中,
包含2021-05-01的记录, 但并不包含2021-05-10最后一天的记录,
好像between and的边界原则失效了, 这是这么回事呢?
问题解答
实际上, between and的查询边界并没有改变, 还是老样子, 只是我们在日期查询时, 一开始把问题想简单了, 实际上还是对于字段类型把握的准确性.
由于时间字段是DATETIME类型, 我们来仔细看看DATETIME数据类型:
DATETIME
A date and time combination.
MariaDB displays DATETIME values in 'YYYY-MM-DD HH:MM:SS.ffffff' format,
but allows assignment of values to DATETIME columns using either strings or numbers.
MariaDB stores values that use the DATETIME data type in a format that supports values
between 1000-01-01 00:00:00.000000 and 9999-12-31 23:59:59.999999.
以上对DATETIME的描述摘自:
https://mariadb.com/kb/en/datetime/ 页面
由此可知, 语句between '2021-05-01' and '2021-05-10'
会被MariaDB数据库转换为
between '2021-05-01 00:00:00.000000' and '2021-05-10 00:00:00.000000'.
这样当然不会包含05-10这一天的记录.
所以, 问题还是出在 查询条件 写得不够严谨, 不要偷懒, 写成下面语句
between '2021-05-01 00:00:00' and '2021-05-10 23:59:59'
就能达到我们想要得目标结果了, 如果数据很多, 时间颗粒度要求高, 也可写成
between '2021-05-01 00:00:00.000000' and '2021-05-10 23:59:59.999999'
就完美了!
更多相关网站
- 云服务器:SQL数据库超时的原因与解决方法
- 一个时间戳精度问题,引发了一个MySQL血案
- (二十二) 程序员必备: 10秒到0.1秒,亿级数据下MySQL慢查询分析教程
- MySQL各种SQL的执行频率
- PGSQL提取本月跨越的周数及每周的开始结束日期
- '0000-00-00'日期可以存入MySQL吗
- 【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)
- 了解SQL吗
- SQL用了两年多,分享2个最常用的小技巧
- 从Sql角度,对比学习Python数据处理包pandas
- SqlServer根据身份证号码查询出生日期和年龄
- 吊打面试官(十一)--Java语言中日期处理相关问题总结
- 玩转MySQL的时间类型:Date、DateTime、TimeStamp、Time
- 多表关联查询的性能优化技巧:预关联
- SQL学习:SQL同比分析案例讲解,一看就懂
- java.util.Date、java.sql.Date、java.sql.Timestamp区别和总结
- 疯传!Java 日期时间底层逻辑大揭秘,看完直接拿捏面试官挖的坑!
- 记一次有意思的 SQL 实现 → 分组后取每组的第一条记录
- 最近发表
-
- 联想推出 IdeaPad 14s / 15s:均为 3399 元,运行 Win11 系统
- 顶配版ThinkPad X1 Carbon评测
- 联想ThinkPad X1 Carbon评测
- lenovo联想 拯救者-14 加装ssd、内存及win10转移到ssd经验谈
- 联想发布新款耳机鼠标等配件:专为ThinkPad X1设计
- 杜比全景音体验,联想K4 Note在印度正式发布
- 3099 元起,联想推出 IdeaPad 15:约10小时续航,预装 Win11系统
- 联想拯救者Y70、小新Pad Pro 2022发布丨拯救者Y70测评体验
- 千元可定制!联想K4 Note印度发布:杜比全景音体验
- 声临其境 联想TAB2 A10平板联手杜比
- 标签列表
-
- serv-u 破解版 (6)
- 极域电子教室2009 (6)
- 6300主题下载 (1)
- oracle11204下载 (1)
- c++论坛 (14)
- huaweiupdateextractor (4)
- thinkphp6下载 (7)
- 前端论坛 (11)
- mysql 时间索引 (13)
- mydisktest_v298 (35)
- unlocker208 (1)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- oppoa5专用解锁工具包 (8)
- acmecadconverter_8.52绿色版 (25)
- oracle timestamp比较大小 (7)
- chm editor破解版 (7)
- throttlestop防止降频 (9)
- f12019破解 (16)
- 流星蝴蝶剑修改器 (18)
- pygame中文手册 (2)
- 联想杜比音效驱动下载 (10)