翼度科技»论坛 编程开发 PHP 查看内容

Laravel Eloquent取上一条和下一条数据的id实现讲解

7

主题

7

帖子

21

积分

新手上路

Rank: 1

积分
21
起源

首先文章的起源来于一个问题:
Laravel的Eloquent ORM 怎么获取当前记录的下一条
我想获取下一条把它的active字段更改为yes,但是这样貌似获取不到
  1. $next_active = $ips->where("id", ">", $ips_get->id)->first();
  2. $next_active->update(["active" => "yes"]);
复制代码
然后,当时在答案里面简单写了一下解决方案。不过由于这个取得下一条和取得上一条的记录其实在日常的开发当中还是会经常遇到,最常见的场景可能就是取得一篇文章的上一篇文章和下一篇文章了。其实这个在
  1. Laravel
复制代码
  1. Eloquent
复制代码
中实现还是挺容易的,不过由于
  1. Laravel
复制代码
并没有直接提供给我们相应的方法,我们得使用一个小小的技巧:

取得上一篇的文章id
  1. protected function getPrevArticleId($id)
  2.     {
  3.         return Article::where('id', '<', $id)->max('id');
  4.     }
复制代码
$id就是当前文章的
  1. id
复制代码
,我们通过
  1. max()
复制代码
来取得比当前
  1. id
复制代码
小的最大值,也就是当前
  1. id
复制代码
的前一篇文章的
  1. id
复制代码


取得下一篇的文章id
  1. protected function getNextArticleId($id)
  2.     {
  3.         return Article::where('id', '>', $id)->min('id');
  4.     }
复制代码
基本上可以说是:
  1. 同理可得
复制代码
。这个取得下一篇文章的
  1. id
复制代码
其实就是一个相反的过程,理解万岁。
一旦我们取得上一篇和下一篇的文章id之后,我们就可以随心所欲了,比如:
  1. $next_article = Article::find($this->getNextArticleId($article->id));
复制代码
多说两句

那如果是对于一个文章的管理来说,我们其实可以这么做:
  1. articles
复制代码
表中增加一个
  1. published_at
复制代码
的字段,这里可以将
  1. published_at
复制代码
字段设置为一个
  1. Carbon
复制代码
对象,然后我们在前端展示的时候就可以根据
  1. published_at
复制代码
来判读是否将文章展示出来。
比如说查询语句:
  1. public function scopePublished($query)
  2.     {
  3.         $query->where('published_at','<=',Carbon::now());
  4.     }
  5. //以上方法位于Article中,下面的查询我放在了ArticleController中
  6. $articles = Article::latest('published_at')->published()...
复制代码
View展示
  1. <li class="previous">
  2. @if($prev_article)
  3. <a href="/post/{{ $prev_article->slug }}" rel="external nofollow"  rel="prev"><i class="fa fa-chevron-left"></i><strong>上一篇</strong><span>  {{ $prev_article->title }}</span> </a>
  4. @endif
  5. </li>
  6. <li class="next">
  7. @if($next_article && $next_article->published_at < Carbon\Carbon::now())
  8. <a href="/post/{{ $next_article->slug }}" rel="external nofollow"  rel="next"><i class="fa fa-chevron-right"></i><strong>下一篇</strong> <span>  {{ $next_article->title }}</span></a>
  9. @endif
  10. </li>
复制代码
处理文章的前一篇和后一篇的解决方案已完成。
以上就是Laravel Eloquent取上一条和下一条数据的id实现讲解的详细内容,更多关于Laravel Eloquent取数据id的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/program/290574vdy.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具