java 计算两个日期之间的天数_3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言

今天说一个细分的需求,在模型中,或者使用laravel提供的 Eloquent ORM 功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?

9743a6329407a55688968674c7e66a32.png

本文通过几个例子,为大家梳理一下。

学习时间

假设有一个模型 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 方法进行筛选。

那么代码实现起来像下面这样:

186825e367c2393ad33da4589816b91a.png

注意程序写起来很柔顺,使用 Carbon 提供的 between 方法进行判断。程序上下文很好理解。

如果考虑初始查询条件圈定的记录条目过多,会对MySQL造成流量的压力,那么在SQL阶段直接筛选出最精准的记录,无疑是个好习惯。whereBetween 在模型里链式调用毫无压力:

94aac36ab24cebe4c93f5db55b3437f5.png

如果你觉得框架自带的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 :-)

我是 @程序员小助手 ,持续分享编程知识,欢迎关注。

Java中可以通过以下两种方式计算两个日期之间相隔的天数: 1. 使用Java 8中的新API Java 8中提供了新的日期时间API,可以通过`java.time`包下的类来计算两个日期之间相隔的天数,具体实现如下: ```java import java.time.LocalDate; import java.time.temporal.ChronoUnit; public class DateUtils { public static long getDaysBetweenTwoDates(LocalDate startDate, LocalDate endDate) { return ChronoUnit.DAYS.between(startDate, endDate); } } ``` 在上面的代码中,我们使用了`ChronoUnit`类的`DAYS`字段来表示计算相隔的天数。接着调用`between()`方法,传入起始日期和结束日期即可计算出相隔的天数。 2. 使用Java 7及以下版本的API 在Java 7及以下版本中,可以使用`java.util.Calendar`类来计算两个日期之间相隔的天数,具体实现如下: ```java import java.util.Calendar; public class DateUtils { public static int getDaysBetweenTwoDates(Calendar startDate, Calendar endDate) { int daysBetween = 0; while (startDate.before(endDate)) { startDate.add(Calendar.DAY_OF_MONTH, 1); daysBetween++; } return daysBetween; } } ``` 在上面的代码中,我们使用了`Calendar`类的`before()`方法来判断起始日期是否早于结束日期。接着,我们通过`add()`方法将起始日期往后推一天,并累加相隔的天数,直到起始日期与结束日期相等为止。 需要注意的是,以上两种方式计算相隔天数的结果可能会因为夏令时、时区等因素导致不准确。如果需要更精确的计算,可以使用第一种方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值