欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年06月28日 11:51:46   作者:JellyBool  
這篇文章主要為大家介紹了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)常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實這個在LaravelEloquent中實現(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)文章

最新評論