with
的話無法limit
數(shù)量的take
也一樣,查到的都是空Post::find($id)->with(['comments'=>function($query){
$query->orderBy('created_at','desc')->limit(10);
}])
------------ 分割線 ----------
如果 with 里的 limit 和 take 不行的話,那么就比較麻煩了,還有其他一些折中的方法。
在 blade 中要顯示評論數(shù)據(jù)的地方 post->comments()->limit(10)
問題:如果取了 20 條 Post 數(shù)據(jù),就會有 20 條取 comments 的 sql 語句,會造成執(zhí)行的 sql 語句過多。
不是非??扇?/blockquote>方法2:
直接通過 with 把 Post 的所有 comments 數(shù)據(jù)都取出來,在 blade 中
post->comments->take(10)
這里的 take 是 Laravel Collection 的方法。兩種方法都可以去構(gòu)造其他查詢條件,過濾自己想要的數(shù)據(jù)。
方法3:
$posts = Post::paginate(15); $postIds = $posts->pluck('id')->all(); $query = Comment::whereIn('post_id',$postIds)->select(DB::raw('*,@post := NULL ,@rank := 0'))->orderBy('post_id'); $query = DB::table( DB::raw("({$query->toSql()}) as b") ) ->mergeBindings($sub->getQuery()) ->select(DB::raw('b.*,IF ( @post = b.post_id ,@rank :=@rank + 1 ,@rank := 1 ) AS rank, @post := b.post_id')); $commentIds = DB::table( DB::raw("({$query->toSql()}) as c") ) ->mergeBindings($sub2) ->where('rank','<',11)->select('c.id')->pluck('id')->toArray(); $comments = Comment::whereIn('id',$commentIds)->get(); $posts = $posts->each(function ($item, $key) use ($comments) { $item->comments = $comments->where('post_id',$item->id); });
親測有效,會產(chǎn)生三條sqlselect * from `posts` limit 15 offset 0; select `c`.`id` from (select b.*,IF ( @post = b.post_id ,@rank :=@rank + 1 ,@rank := 1 ) AS rank, @post := b.post_id from (select *,@post := NULL ,@rank := 0 from `comments` where `post_id` in ('2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16') order by `id` asc) as b) as c where `rank` < '11'; select * from `comments` where `id` in ('180', '589', '590', '3736');
其實該問題的難點是在于:在文章列表時候,要把文章的相關(guān)評論取N條,之前
with
的take
不行,是因為mysql
的語法不像SQL Server
和Order
那樣支持over partition by
分組。所以方法3實現(xiàn)的是類似
over partition by
這樣的分組功能。comments
表根據(jù)post_id
進(jìn)行分組,然后計數(shù)獲得rank
,然后取 rank < 11 的數(shù)據(jù),也就是前 10 條數(shù)據(jù)。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。