-
3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
- 网站名称:3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
- 网站分类:技术文章
- 收录时间:2025-06-08 15:51
- 网站地址:
“3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?” 网站介绍
引言
今天说一个细分的需求,在模型中,或者使用laravel提供的 Eloquent ORM 功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?
本文通过几个例子,为大家梳理一下。
学习时间
假设有一个模型 Reservation,我们查询某个日期的预订条目数,首先构造日期字符串,使用内置函数:
$now = date('Y-m-d');
返回当前日期。然后调用模型的 where 查询语句:
$reservations = Reservation::where('reservation_from', $now)->get();
上一条生成的SQL语句如下:
select * from table_name where reservation_from = $now
只会返回日期比较相等的条目。如何实现在 from 和 to 之间的日期呢,类似下面这样:
SELECT * FROM table_name WHERE reservation_from BETWEEN '$from' AND '$to
在laravel中你可以使用 whereBetween 这个查询子句。首先构造起始和结束日期:
$from = date('2020-01-01');
$to = date('2020-08-09');
然后调用查询子句:
Reservation::whereBetween('reservation_from', [$from, $to])->get();
这样就返回SQL查询的 BETWEEN ... AND .... 语句了。
当然了,上面的方法是在SQL中直接进行筛选,如果查询结果限制的条目本身比较少,也能充分利用索引,所以不担心查询的速度,那么我们可以在查询完成后,在返回的 Eloquent Collection 集合上,链式调用过滤 filter 方法进行筛选。
那么代码实现起来像下面这样:
注意程序写起来很柔顺,使用 Carbon 提供的 between 方法进行判断。程序上下文很好理解。
如果考虑初始查询条件圈定的记录条目过多,会对MySQL造成流量的压力,那么在SQL阶段直接筛选出最精准的记录,无疑是个好习惯。whereBetween 在模型里链式调用毫无压力:
如果你觉得框架自带的where子句不足以满足你的查询需求,那么直接用原生查询条件好了,用 whereRaw 就可以了,像下面的例子,先构造查询区间:
$fromDate = "2020-02-01";
$toDate = "2016-06-30";
然后使用参数绑定:
$reservations = Reservation::whereRaw("(reservation_from >= ? AND reservation_from <= ?)", [$fromDate." 00:00:00", $toDate." 23:59:59"])->get();
别的办法
假如上面的写法你觉得不够直观,或者很难把握,那就跟着直觉走。判断日期之间,无非就是大于某个日期,且小于某个日期这样。那直接用大小比较就行了。
其实between这个关键字,在MySQL中也不过是大小比较的缩写语法糖。那么就可以把程序写成下面这样:
$reservations = Reservation::where('reservation_from', '>=', $from)
->where('reservation_from', '<=', $to)
->get();
写在最后
本文通过3种写法实现了对于日期之间的SQL查询,我们建议使用SQL语句的限制,将筛选的结果精准返回,然后做进一步操作。laravel虽然提供了集合操作,但是在数据库侧效率并不高,所以不提倡全量查询,集合筛选这样的操作。
Happy coding :-)
我是 @程序员小助手 ,持续分享编程知识,欢迎关注。
更多相关网站
- 云服务器: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 实现 → 分组后取每组的第一条记录
- 最近发表
-
- JavaScript,ES6,数值扩展,二进制、八进制和十六进制,方法
- 如何用2 KB代码实现3D赛车游戏?2kPlus Jam大赛了解一下
- 10个JavaScript一行代码,解决90%的开发难题
- 如何使用 Fraction.js 解决 BigInt 的计算盲区?
- js四舍五入(js中四舍五入的代码怎么打)
- 全能硬件大师AIDA64 v4.60 最新绿色版下载
- 实用神帖 隔壁老王买到iPhone 6魔改6s,怎么破?
- DIY装机小白的618配机历程(3千元的146K,DDR5无卡方案)2025
- AIDA64 7.30版本发布:改善深色/高对比度模式
- DIY从入门到放弃:CPU没有SN码是保护你
- 标签列表
-
- mydisktest_v298 (35)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- acmecadconverter_8.52绿色版 (25)
- 梦幻诛仙表情包 (36)
- 魔兽模型 (23)
- java面试宝典2019pdf (26)
- disk++ (30)
- 加密与解密第四版pdf (29)
- iteye (26)
- parsevideo (22)
- centos7.4下载 (32)
- cuda10.1下载 (22)
- intouch2014r2sp1永久授权 (33)
- usb2.0-serial驱动下载 (24)
- jdk1.8.0_191下载 (27)
- axure9注册码 (30)
- virtualdrivemaster (26)
- 数据结构c语言版严蔚敏pdf (25)
- 兔兔工程量计算软件下载 (27)
- 代码整洁之道 pdf (26)
- ccproxy破解版 (31)
- aida64模板 (28)