Laravel的Eloquent ORM 怎么获取当前记录的下一条
然后,当时在答案里面简单写了一下解决方案。不过由于这个取得下一条和取得上一条的记录其实在日常的开发当中还是会经常遇到,最常见的场景可能就是取得一篇文章的上一篇文章和下一篇文章了。其实这个在Laravel的Eloquent中实现还是挺容易的,不过由于Laravel并没有直接提供给我们相应的方法,我们得使用一个小小的技巧:
rush:PHP;">
protected function getPrevArticleId($id)
{
return Article::where('id','<',$id)->max('id');
}
$id就是当前文章的id,我们通过max()来取得比当前id小的最大值,也就是当前id的前一篇文章的id。
',$id)->min('id');
}
基本上可以说是:同理可得。这个取得下一篇文章的id其实就是一个相反的过程,理解万岁。
一旦我们取得上一篇和下一篇的文章id之后,我们就可以随心所欲了,比如:
代码如下:
getNextArticleId($article->id));
多说两句
给articles表中增加一个published_at的字段,这里可以将published_at字段设置为一个Carbon对象,然后我们在前端展示的时候就可以根据published_at来判读是否将文章展示出来。
比如说查询语句:
where('published_at','<=',Carbon::Now());
}
//以上方法位于Article中,下面的查询我放在了ArticleController中
published()...
View展示:
rush:xhtml;">
IoUs">
@if($prev_article)
published_at < Carbon\Carbon::Now())
@endif
上一篇
{{ $prev_article->title }} @endif<a href="/post/{{ $next_article->slug }}" rel="next"><i class="fa fa-chevron-right">
下一篇
{{ $next_article->title }}@endif
以上所述就是本文的全部内容了,希望大家能够喜欢。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。