Laravel?Eloquent取上一條和下一條數(shù)據(jù)的id實現(xiàn)講解
起源
首先文章的起源來于一個問題:
Laravel的Eloquent ORM 怎么獲取當前記錄的下一條
我想獲取下一條把它的active字段更改為yes,但是這樣貌似獲取不到
$next_active = $ips->where("id", ">", $ips_get->id)->first(); $next_active->update(["active" => "yes"]);
然后,當時在答案里面簡單寫了一下解決方案。不過由于這個取得下一條和取得上一條的記錄其實在日常的開發(fā)當中還是會經(jīng)常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實這個在Laravel
的Eloquent
中實現(xiàn)還是挺容易的,不過由于Laravel
并沒有直接提供給我們相應的方法,我們得使用一個小小的技巧:
取得上一篇的文章id
protected function getPrevArticleId($id) { return Article::where('id', '<', $id)->max('id'); }
$id就是當前文章的id
,我們通過max()
來取得比當前id
小的最大值,也就是當前id
的前一篇文章的id
。
取得下一篇的文章id
protected function getNextArticleId($id) { return Article::where('id', '>', $id)->min('id'); }
基本上可以說是:同理可得
。這個取得下一篇文章的id
其實就是一個相反的過程,理解萬歲。
一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,比如:
$next_article = Article::find($this->getNextArticleId($article->id));
多說兩句
那如果是對于一個文章的管理來說,我們其實可以這么做:
給articles
表中增加一個published_at
的字段,這里可以將published_at
字段設(shè)置為一個Carbon
對象,然后我們在前端展示的時候就可以根據(jù)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="/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="/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實現(xiàn)講解的詳細內(nèi)容,更多關(guān)于Laravel Eloquent取數(shù)據(jù)id的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
PHP網(wǎng)頁緩存技術(shù)優(yōu)點及代碼實例
這篇文章主要介紹了PHP網(wǎng)頁緩存技術(shù)優(yōu)點及代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07PHP5下$_SERVER變量不再受magic_quotes_gpc保護的彌補方法
在php5的環(huán)境中我們的$_SERVER變量將不再受magic_quotes_gpc的保護,至于程序該如何加強自己的安全性,下面我們總結(jié)了怎么保護php中的cookie,get,post,files數(shù)據(jù)哦,有需要的朋友可參考一下2012-10-10PHP對象轉(zhuǎn)換為數(shù)組函數(shù)(遞歸方法)
本方法主要是應用于迭代對象。我應用的地方是simplexml中的simplexml_load_string()上,因為返回的全是對象,如果提取數(shù)據(jù)比較麻煩,所以應用了下面的函數(shù)2012-02-02PHP實現(xiàn)數(shù)組和對象的相互轉(zhuǎn)換操作示例
這篇文章主要介紹了PHP實現(xiàn)數(shù)組和對象的相互轉(zhuǎn)換操作,結(jié)合實例形式分析了php使用get_object_vars以數(shù)組形式訪問對象的方法,以及對象與數(shù)組相互轉(zhuǎn)換操作技巧,需要的朋友可以參考下2019-03-03詳解WordPress中用于合成數(shù)組的wp_parse_args()函數(shù)
這篇文章主要介紹了WordPress中用于合成數(shù)組的wp_parse_args()函數(shù),轉(zhuǎn)換成數(shù)組通常是為了方便查詢,需要的朋友可以參考下2015-12-12php通過Chianz.com獲取IP地址與地區(qū)的方法
這篇文章主要介紹了php通過Chianz.com獲取IP地址與地區(qū)的方法,是解析IP地址與地區(qū)非常實用的技巧,需要的朋友可以參考下2015-01-01Fatal error: Call to undefined function curl_init()解決方法
Fatal error: Call to undefined function curl_init()解決方法2010-04-04