繁体   English   中英

Laravel 选择特定年份的记录

[英]Laravel Select records in specific year

我是 Laravel 的新手,正在努力确定如何使用时间戳提供的 created_at 字段选择 2015 年创建的所有记录。

我使用的模型是博客:

$posts = Blog::latest()->get();

数据库中的示例日期:

2015-01-25 12:53:27

有人能解释一下吗?

谢谢!

您可以这样操作: $posts = Blog::where( DB::raw('YEAR(created_at)'), '=', '2015' )->get();

在这里,您可以使用YEAR函数从created_at字段中获取年份,然后与您的日期进行比较。

只是为了完成。 有一个Laravel方法。

Blog::whereYear('created_at', 2017)->get();

请参阅where子句其中小节whereDate / whereMonth / whereDay / whereYear

您可以在模型中使用范围功能。 例如:

您的模型

class Blog extends Eloquent {
    public function scopePopular($query,$year)
    {
        return $query->where('year', '=', $year);
    }
}

用法

$blog = Blog::popular(1999)-get();

作用域函数对我来说完美无缺:

class Blog extends Eloquent {
public function scopeSeason($query,$year)
{
    return $query->whereYear('created_at', '=', $year);
}

}

用法:

$blog = Blog::where('status','active')->season(2021)->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM