with的話無法limit數量的take也一樣,查到的都是空Post::find($id)->with(['comments'=>function($query){
$query->orderBy('created_at','desc')->limit(10);
}])
------------ 分割線 ----------
如果 with 里的 limit 和 take 不行的話,那么就比較麻煩了,還有其他一些折中的方法。
在 blade 中要顯示評論數據的地方 post->comments()->limit(10)
問題:如果取了 20 條 Post 數據,就會有 20 條取 comments 的 sql 語句,會造成執(zhí)行的 sql 語句過多。
不是非??扇?/blockquote>方法2:
直接通過 with 把 Post 的所有 comments 數據都取出來,在 blade 中
post->comments->take(10)這里的 take 是 Laravel Collection 的方法。兩種方法都可以去構造其他查詢條件,過濾自己想要的數據。
方法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); });親測有效,會產生三條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');
其實該問題的難點是在于:在文章列表時候,要把文章的相關評論取N條,之前
with的take不行,是因為mysql的語法不像SQL Server和Order那樣支持over partition by分組。所以方法3實現的是類似
over partition by這樣的分組功能。comments表根據post_id進行分組,然后計數獲得rank,然后取 rank < 11 的數據,也就是前 10 條數據。
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數據專業(yè)的國家
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產業(yè)為響應國家深化產教融合/校企合作的政策,積極推進“中國制造2025”,實現中華民族偉大復興的升級產業(yè)鏈。利用北京大學優(yōu)質教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經理從事移動互聯(lián)網管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經理職務負責iOS教學及管理工作。
浪潮集團項目經理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網頁制作和網頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經驗。曾經歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。