像梦一样奔驰|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虽然提供了集合操作 , 但是在数据库侧效率并不高 , 所以不提倡全量查询 , 集合筛选这样的操作 。
- 芒种风向标|奔驰全新S级的内饰好看吗?不得不说优秀全靠同行衬托
- 光明论|劳动者的尊严不能像证件一样被“扔”在地上
- 王者荣耀|没有明世隐的“狼狗”不能玩?正确玩法教给你一样凯瑞全场!
- 像梦一样奔驰|51WDP开发者平台五大工具全面开放,让数字孪生触手可及
- 汽车知识|奔驰全新S级的内饰好看吗?不得不说优秀全靠同行衬托
- 体育多看|若他留在湖人,能享受和科比一样的待遇吗?,詹姆斯38岁合同到期
- 杨毅|理智看球!杨毅:像威少爷这种,就像没学过打球一样
- 光一样的少年|面对后起之秀,苏泊尔不玩价格战,以一抵八多功能破壁机倍受追捧
- 带翅膀的蜗牛|国家一级演员,孝女关牧村,把高龄父亲当成孩子一样呵护
- 穿搭|黑白灰太单调?这样穿体现不一样的气质,打造不一样的美