久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

Laravel?Eloquent取上一條和下一條數據的id實現講解

瀏覽:4日期:2022-06-13 18:11:18
目錄起源取得上一篇的文章id取得下一篇的文章id多說兩句View展示起源

首先文章的起源來于一個問題:

Laravel的Eloquent ORM 怎么獲取當前記錄的下一條

我想獲取下一條把它的active字段更改為yes,但是這樣貌似獲取不到

$next_active = $ips->where('id', '>', $ips_get->id)->first();$next_active->update(['active' => 'yes']);

然后,當時在答案里面簡單寫了一下解決方案。不過由于這個取得下一條和取得上一條的記錄其實在日常的開發當中還是會經常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實這個在Laravel的Eloquent中實現還是挺容易的,不過由于Laravel并沒有直接提供給我們相應的方法,我們得使用一個小小的技巧:

取得上一篇的文章idprotected function getPrevArticleId($id) {return Article::where('id', '<', $id)->max('id'); }

$id就是當前文章的id,我們通過max()來取得比當前id小的最大值,也就是當前id的前一篇文章的id。

取得下一篇的文章idprotected function getNextArticleId($id) {return Article::where('id', '>', $id)->min('id'); }

基本上可以說是:同理可得。這個取得下一篇文章的id其實就是一個相反的過程,理解萬歲。

一旦我們取得上一篇和下一篇的文章id之后,我們就可以隨心所欲了,比如:

$next_article = Article::find($this->getNextArticleId($article->id));多說兩句

那如果是對于一個文章的管理來說,我們其實可以這么做:

給articles表中增加一個published_at的字段,這里可以將published_at字段設置為一個Carbon對象,然后我們在前端展示的時候就可以根據published_at來判讀是否將文章展示出來。

比如說查詢語句:

public function scopePublished($query) {$query->where('published_at','<=',Carbon::now()); }//以上方法位于Article中,下面的查詢我放在了ArticleController中$articles = Article::latest('published_at')->published()...View展示<li class='previous'>@if($prev_article)<a href='https://www.jb51.net/post/{{ $prev_article->slug }}' rel='external nofollow' rel='prev'><i class='fa fa-chevron-left'></i><strong>上一篇</strong><span> {{ $prev_article->title }}</span> </a>@endif</li><li class='next'>@if($next_article && $next_article->published_at < Carbon\Carbon::now())<a href='https://www.jb51.net/post/{{ $next_article->slug }}' rel='external nofollow' rel='next'><i class='fa fa-chevron-right'></i><strong>下一篇</strong> <span> {{ $next_article->title }}</span></a>@endif</li>

處理文章的前一篇和后一篇的解決方案已完成。

以上就是Laravel Eloquent取上一條和下一條數據的id實現講解的詳細內容,更多關于Laravel Eloquent取數據id的資料請關注好吧啦網其它相關文章!

標簽: PHP
主站蜘蛛池模板: 宁海县| 昔阳县| 青川县| 襄汾县| 大新县| 江永县| 吴桥县| 喀喇| 六安市| 德昌县| 通渭县| 安多县| 明水县| 保亭| 西乌| 长乐市| 潼南县| 平武县| 黎川县| 海林市| 南汇区| 太谷县| 秭归县| 藁城市| 罗定市| 阳信县| 平乐县| 龙南县| 章丘市| 舞阳县| 辰溪县| 游戏| 岫岩| 张家港市| 甘孜县| 缙云县| 奎屯市| 盐津县| 东港市| 永嘉县| 瓮安县|