当前位置: 首页 > 知识库问答 >
问题:

如何使用Laravel和Eloquent查询两个日期之间的信息?

容宏逸
2023-03-14

我正在尝试创建一个报告页面,显示从特定日期到特定日期的报告。以下是我当前的代码:

$now = date('Y-m-d');
$reservations = Reservation::where('reservation_from', $now)->get();

这在普通SQL中的作用是select*from表,其中reservation\u from=$now

我在这里有这个查询,但我不知道如何将其转换为雄辩的查询。

SELECT * FROM table WHERE reservation_from BETWEEN '$from' AND '$to

如何将上面的代码转换为雄辩的查询?提前谢谢你。

共有3个答案

冀鸿才
2023-03-14

如果要检查当前日期是否存在于数据库中的两个日期之间:=

$list=  (new LeaveApplication())
            ->whereDate('from','<=', $today)
            ->whereDate('to','>=', $today)
            ->get();
乌学博
2023-03-14

如果您的字段是datetime而不是date,则另一个选项(尽管它适用于两种情况):

$fromDate = "2016-10-01";
$toDate   = "2016-10-31";

$reservations = Reservation::whereRaw(
  "(reservation_from >= ? AND reservation_from <= ?)", 
  [
     $fromDate." 00:00:00", 
     $toDate." 23:59:59"
  ]
)->get();
贲招
2023-03-14

方法验证列的值是否在两个值之间。

$from = date('2018-01-01');
$to = date('2018-05-02');

Reservation::whereBetween('reservation_from', [$from, $to])->get();

在某些情况下,您需要动态添加日期范围。根据@Anovative的评论,您可以这样做:

Reservation::all()->filter(function($item) {
  if (Carbon::now()->between($item->from, $item->to)) {
    return $item;
  }
});

如果要添加更多条件,则可以使用或wherebetween。如果要排除日期间隔,则可以使用whereNotBetween

Reservation::whereBetween('reservation_from', [$from1, $to1])
  ->orWhereBetween('reservation_to', [$from2, $to2])
  ->whereNotBetween('reservation_to', [$from3, $to3])
  ->get();

其他有用的where子句:其中何地何地何地何地月份何地日期何地年何地时间何地列何地存在何地

Laravel记录了Where子句。

 类似资料:
  • 问题内容: 我正在尝试创建一个报告页面,以显示从特定日期到特定日期的报告。这是我当前的代码: 这在普通SQL中的作用是。 我在这里有此查询,但我不知道如何将其转换为雄辩的查询。 如何将上面的代码转换为雄辩的查询?先感谢您。 问题答案: 该方法验证列的值是否在两个值之间。 在某些情况下,您需要动态添加日期范围。根据@Anovative的评论,您可以执行以下操作: 如果您想添加更多条件,则可以使用。如

  • 问题内容: 以下查询: 什么也不返回。 我应该有足够多的数据来使查询工作。我究竟做错了什么? 问题答案: 您的第二个日期早于您的第一个日期(即,您正在查询2010年9月29日至2010年1月30日之间)。尝试颠倒日期的顺序:

  • 这是我在SQL Server上的查询: 使用JPA存储库的正确语法是什么? 我试过这个: 并收到此错误: 验证失败,无法查询方法 public abstract java.lang.Long com.finance.biblioteca.repository.NoleggioRepository.countByUtenteIdAndLibroId(java.lang.Long,java.lang.

  • 问题内容: 我想查询一个mySQL表以提取两次和两次之间的数据。我知道如何使用“ between”调用对单个“ datetime”列执行此操作,但是我的列是一个“ date”列和一个“ time”列。我在网上可以找到的所有解决方案都是针对单个datetime列的。 我的范围从15:30的“ day1”到15:14的day1 + 1day 到目前为止,我可以获得以下范围(有效): 但是我显然需要合并

  • 问题内容: 以下查询: 什么也不返回。 我应该有足够多的数据来使查询工作。我究竟做错了什么? 问题答案: 您的第二个日期早于您的第一个日期(即,您正在查询2010年9月29日至2010年1月30日之间)。尝试颠倒日期的顺序:

  • 问题内容: 我有一个和。我想获取这两个日期之间的日期列表。谁能帮助我指出查询中的错误。 这是一个变量。 问题答案: 您应该将这两个日期放在单引号之间,例如。 或可以使用 请记住,第一个日期是包含日期,但第二个日期是排除日期,因为它实际上是“ 2011/02/27 00:00:00”