亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

Laravel關聯模型中過濾結果為空的結果集(has和with區別)

2024-05-05 00:05:41
字體:
來源:轉載
供稿:網友

首先看代碼:

$userCoupons = UserCoupons::with(['coupon' => function($query) use($groupId){ return $query->select('id', 'group_id', 'cover', 'group_number', 'group_cover')->where([   'group_id' => $groupId, ]);}])// 更多查詢省略...

數據結構是三張表用戶優惠券表(user_coupons)、優惠券表(coupons),商家表(corps),組優惠券表(group_coupons) (為了方便查看,后兩項已去除)

這里我本意想用模型關聯查出用戶優惠券中屬于給定組gourpId的所有數據(如果為空該條數據就不返回)。

但有些結果不是我想要的:

array(20) { ["id"]=> int(6) ["user_id"]=> int(1) ["corp_id"]=> int(1) ["coupon_id"]=> int(4) ["obtain_time"]=> int(1539739569) ["receive_time"]=> int(1539739569) ["status"]=> int(1) ["expires_time"]=> int(1540603569) ["is_selling"]=> int(0) ["from_id"]=> int(0) ["sell_type"]=> int(0) ["sell_time"]=> int(0) ["sell_user_id"]=> int(0) ["is_compose"]=> int(0) ["group_cover"]=> string(0) "" ["is_delete"]=> int(0) ["score"]=> int(100) ["created_at"]=> NULL ["updated_at"]=> NULL ["coupon"]=> NULL // 注意返回了coupons為空的數據}

記錄中有的coupon有記錄,有的為空。想想也是,with只是用sql的in()實現的所謂預加載。無論怎樣主user_coupons的數據都是會列出的。

它會有兩條sql查詢,第一條查主數據,第二條查關聯,這里第二條sql如下:

select `id`, `group_id`, `cover`, `group_number`, `group_cover` from `youquan_coupons` where `youquan_coupons`.`id` in (1, 2, 3, 4, 5, 7, 8, 9, 10, 11, 13, 14) and (`group_id` = 1) and `youquan_coupons`.`deleted_at` is null

如果第二條為空,主記錄的關聯字段就是NULL。

后來看到了Laravel關聯的模型的has()方法,has()是基于存在的關聯查詢,下面我們用whereHas()(一樣作用,只是更高級,方便寫條件)

這里我們思想是把判斷有沒有優惠券數據也放在第一次查詢邏輯中,所以才能實現篩選空記錄。

加上whereHas()后的代碼如下

$userCoupons = UserCoupons::whereHas('coupon', function($query) use($groupId){  return $query->select('id', 'group_id', 'cover', 'group_number', 'group_cover')->where([   'group_id' => $groupId,  ]); })->with(['coupon' => function($query) use($groupId){  return $query->select('id', 'group_id', 'cover', 'group_number', 'group_cover'); }])-> // ...

看下最終的SQL:

select * from `youquan_user_coupons` where exists (select `id`, `group_id`, `cover`, `group_number`, `group_cover` from `youquan_coupons` where `youquan_user_coupons`.`coupon_id` = `youquan_coupons`.`id` and (`group_ids` = 1) and `youquan_coupons`.`deleted_at` is null) and (`status` = 1 and `user_id` = 1)

這里實際上是用exists()篩選存在的記錄。然后走下一步的with()查詢,因為此時都篩選一遍了,所以with可以去掉條件。

顯然區分這兩個的作用很重要,尤其是在列表中,不用特意去篩選為空的數據,而且好做分頁。

總結

以上所述是小編給大家介紹的Laravel關聯模型中過濾結果為空的結果集(has和with區別),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美自拍视频在线观看| 久久精品成人欧美大片古装| 在线播放日韩精品| 成人有码视频在线播放| 色午夜这里只有精品| 欧美中文在线观看国产| 国产精品无av码在线观看| 欧美电影在线观看网站| 日韩男女性生活视频| 久久精品视频99| 亚洲成人久久网| 日韩精品久久久久久福利| 免费不卡欧美自拍视频| 亚洲护士老师的毛茸茸最新章节| 中国china体内裑精亚洲片| 欧美视频国产精品| 在线亚洲国产精品网| 日韩欧美在线一区| 97人洗澡人人免费公开视频碰碰碰| 日韩福利在线播放| 欧美性猛交xxxx富婆弯腰| 国语自产精品视频在线看抢先版图片| 日韩精品在线视频美女| 亚洲男人天堂手机在线| 欧美一区三区三区高中清蜜桃| 欧美精品一区在线播放| 亚洲国产日韩欧美综合久久| 久久久噜噜噜久久| 麻豆成人在线看| 91av在线视频观看| 亚洲欧美精品在线| 精品久久久一区| 91精品在线播放| 欧美日本啪啪无遮挡网站| 色av中文字幕一区| 粉嫩老牛aⅴ一区二区三区| 亚洲区bt下载| 欧美成人精品在线| 欧美大片欧美激情性色a∨久久| 91视频国产精品| 欧美老女人在线视频| 日韩av影院在线观看| 国产99视频在线观看| 日韩小视频在线观看| 久久中文精品视频| 久久欧美在线电影| 久久福利网址导航| 2020欧美日韩在线视频| 日本一区二区在线免费播放| 欧美限制级电影在线观看| 精品国产福利视频| 久国内精品在线| 久久久精品国产网站| 亚洲а∨天堂久久精品喷水| 欧美国产欧美亚洲国产日韩mv天天看完整| 福利微拍一区二区| 97精品视频在线播放| 日本精品va在线观看| 国产精品久久久av久久久| 亚洲美女自拍视频| 亚洲第一综合天堂另类专| 麻豆一区二区在线观看| 最近中文字幕mv在线一区二区三区四区| 成人国内精品久久久久一区| 日韩精品视频在线| 国产精品欧美一区二区三区奶水| 精品久久国产精品| 国产亚洲精品一区二区| 午夜精品久久久久久久99黑人| 亚洲成人av在线播放| 91av视频导航| 国产成人精品久久二区二区| 欧美日韩在线视频首页| 欧美日韩国产精品一区| 亚洲免费视频一区二区| 国产91精品青草社区| 92福利视频午夜1000合集在线观看| 亚洲最大福利视频网| 国产精品精品久久久久久| 国产亚洲欧洲高清| 中文字幕亚洲一区在线观看| 91精品国产高清久久久久久久久| 久久久亚洲欧洲日产国码aⅴ| 日韩av片永久免费网站| 久久香蕉精品香蕉| 精品成人乱色一区二区| 亚洲综合中文字幕68页| 亚洲第一二三四五区| 久久久91精品| 国产一区二区三区日韩欧美| 正在播放欧美一区| 久久久精品一区二区三区| 久久免费高清视频| 91亚洲国产成人精品性色| 九九九久久国产免费| 欧美最猛性xxxxx亚洲精品| 亚洲精品美女视频| 亚洲欧洲日产国码av系列天堂| 国产一区深夜福利| 97视频在线观看亚洲| 综合国产在线观看| 久久国产精品久久久久久| 亚洲成人激情小说| 国产精品一二三在线| 97人人爽人人喊人人模波多| 欧美高跟鞋交xxxxxhd| 亚洲一区第一页| 亚洲国产精品va在看黑人| 2019中文字幕全在线观看| 亚洲第一精品久久忘忧草社区| 91精品国产乱码久久久久久蜜臀| 91免费人成网站在线观看18| 91亚洲精品在线| 欧美成人午夜剧场免费观看| 九九热精品视频国产| 亚洲人成绝费网站色www| 亚洲精品久久久久久久久| 91美女片黄在线观| 中文字幕欧美日韩| 日韩av在线精品| 国产日韩欧美黄色| 奇米四色中文综合久久| 中文字幕日韩精品在线观看| 精品视频在线导航| 欧美精品免费看| 欧美亚洲免费电影| 日韩综合视频在线观看| 91国内在线视频| 久久人人爽人人爽爽久久| 亚洲电影免费观看高清完整版在线观看| 久久久精品国产| 精品久久中文字幕久久av| 成人欧美一区二区三区黑人| 久久久久国产精品免费网站| 久久精品视频99| 国产精品日本精品| 日韩av影视综合网| 日韩在线免费视频观看| 亚洲精品福利视频| 国产热re99久久6国产精品| 久久国产精品久久久久久| 欧美一级电影久久| 国产欧美va欧美va香蕉在| 日本欧美黄网站| 国产色婷婷国产综合在线理论片a| 久久久久久国产| 亚洲黄色有码视频| 福利一区视频在线观看| 成人午夜小视频| 91香蕉国产在线观看| 国产精品专区第二| 在线视频国产日韩| 成人妇女淫片aaaa视频| 欧美性xxxx18| 日韩av快播网址| 97在线精品国自产拍中文| 国产精品久久久久国产a级| 91亚洲va在线va天堂va国| 91夜夜揉人人捏人人添红杏| 亚洲久久久久久久久久久| 欧美成aaa人片免费看| 国产精品大陆在线观看| 亚洲欧洲在线观看| 欧美性猛交xxxx富婆弯腰|