在laravel中使用with实现动态添加where条件

时间:2022-07-27
本文章向大家介绍在laravel中使用with实现动态添加where条件,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

关键点:闭包

模型:

public function getCollect()
  {
    return $this- belongsTo('AppComponentsMiscModelsCollectCareerTalk', 'id', 'career_talk_id');
   }
 
public function otherMethod()
  {
    return $this- belongsTo('AppComponentsMiscModelsOtherMethodModel', '主键', '外键');
   }

仓库:

$this- model- with(['getCollect' =  function ($q) use ($user_id) {
                      $q- where('user_id', $user_id);
                    },
                  'otherMethod'])
            - select('id', 'title')
            - where([
              'id' =  1
            ])
            - first();

注意:with可以连多个表(数组形式传参),没有动态条件的,可以直接讲模型方法名写到with的参数中,有动态条件的,写到闭包中

以上这篇在laravel中使用with实现动态添加where条件就是小编分享给大家的全部内容了,希望能给大家一个参考。