国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Laravel?Eloquent取上一條和下一條數(shù)據(jù)的id實(shí)現(xiàn)講解

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

首先文章的起源來(lái)于一個(gè)問(wèn)題:

Laravel的Eloquent ORM 怎么獲取當(dāng)前記錄的下一條

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

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

然后,當(dāng)時(shí)在答案里面簡(jiǎn)單寫(xiě)了一下解決方案。不過(guò)由于這個(gè)取得下一條和取得上一條的記錄其實(shí)在日常的開(kāi)發(fā)當(dāng)中還是會(huì)經(jīng)常遇到,最常見(jiàn)的場(chǎng)景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實(shí)這個(gè)在Laravel的Eloquent中實(shí)現(xiàn)還是挺容易的,不過(guò)由于Laravel并沒(méi)有直接提供給我們相應(yīng)的方法,我們得使用一個(gè)小小的技巧:

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

$id就是當(dāng)前文章的id,我們通過(guò)max()來(lái)取得比當(dāng)前id小的最大值,也就是當(dāng)前id的前一篇文章的id。

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

基本上可以說(shuō)是:同理可得。這個(gè)取得下一篇文章的id其實(shí)就是一個(gè)相反的過(guò)程,理解萬(wàn)歲。

一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,比如:

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

那如果是對(duì)于一個(gè)文章的管理來(lái)說(shuō),我們其實(shí)可以這么做:

給articles表中增加一個(gè)published_at的字段,這里可以將published_at字段設(shè)置為一個(gè)Carbon對(duì)象,然后我們?cè)谇岸苏故镜臅r(shí)候就可以根據(jù)published_at來(lái)判讀是否將文章展示出來(lái)。

比如說(shuō)查詢語(yǔ)句:

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取上一條和下一條數(shù)據(jù)的id實(shí)現(xiàn)講解的詳細(xì)內(nèi)容,更多關(guān)于Laravel Eloquent取數(shù)據(jù)id的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: PHP
主站蜘蛛池模板: 翁源县| 满洲里市| 延吉市| 巴塘县| 会理县| 承德县| 镇平县| 昌宁县| 额敏县| 饶平县| 古丈县| 北票市| 若羌县| 南康市| 阳高县| 香格里拉县| 新闻| 邹城市| 子洲县| 广饶县| 武宣县| 西乌| 本溪市| 田东县| 曲阜市| 乌兰县| 山阴县| 肃宁县| 凌云县| 常宁市| 祁门县| 互助| 灵川县| 手机| 太原市| 韩城市| 大同县| 徐州市| 冕宁县| 泾川县| 措美县|