Laravel关联模型查询

一,多表关联

文章表articles 和user_id,category_id关联

php 复制代码
//with()方法是渴求式加载,缓解了1+N的查询问题,仅需1+1次查询就能解决问题,可以提升查询速度。with部分没有就以null输出,所以可以理解为  多表  left join 查询
//has()和whereHas() 是基于关联关系去过滤模型的查询结果,如果关联模型不符合条件那整体就没有数据。所以可以理解为多表  inner join 查询。
  • 模型关系
php 复制代码
public function user(){
	return $this->belongsTo('App\Models\User','user_id','id');
}


//表2
 public function category(){
	return $this->belongsTo('App\Models\Category','category_id','id');
 }
  • 控制器
php 复制代码
//输出文章表中所有文章数据,如果符合用户id=1,分类name=科技 就输出关联的信息,没有就是null,类似left join 查询
$list = Article::with([
    'user'=>function($query){
        $query->where('id', '=', '1');
    },
    'category'=>function($query){
        $query->where('name', '=', '科技');
    },
    '模型定义的方法名'=>function($query){
     	$query->where('name', '=', '科技');
    }
])
->where('status',1)
->get();
php 复制代码
//输出文章表中符合条件的文章,需要满足用户id=1,分类name=科技 的条件,类似 inner join
//这里要注意,whereHas和has只做筛选,并不返回关系user和category中的数据,但是 with 是返回的。所以,当要返回关系数据时,两者要结合使用。
$list = Article::whereHas('user',function($query){
	$query->where('id', '=', '1');
})
->whereHas('category',function($query){
	$query->where('name', '=', '科技');
})
//这里的with 其实不用再写条件也行,因为前面的whereHas 已经限定了条件了
->with([
    'user'=>function($query){
        $query->where('id', '=', '1');
    },
    'category'=>function($query){
        $query->where('name', '=', '科技');
    }
])
->where('status',1)
->get();

实际使用

php 复制代码
//$request->has() 判断参数是否存在,$request->filled() 判断参数存在且不为空
$id = $request->get('id');
$list = Article::whereHas('user',function($query) use ($id){
	if(!empty($id)){
		$query->where('id', '=', $id);
	}
	
})
->whereHas('category',function($query){
	$query->where('name', '=', '科技');
})
//这里的with 其实不用再写条件也行,因为前面的whereHas 已经限定了条件了
->with([
    'user'=>function($query){
        $query->where('id', '=', '1');
    },
    'category'=>function($query){
        $query->where('name', '=', '科技');
    }
])
->where('status',1)
->get();

二,多表多层级嵌套关联查询

一个company有多个store,一个store有多个goods

php 复制代码
$limit = $request->limit ?? 10;
$query = Goods::query()->where(['status' => 1]);
// 如果存在请求的公司,获取请求公司所有商家的每款产品
if ($request->company_ids){
    $companyIdsArr = explode(',', $request->company_ids);
    $query->whereHas('business', function ($query) use($companyIdsArr){
        $query->whereHas('commpany', function ($query) use($companyIdsArr){
            $query->whereIn('id', $companyIdsArr);
        });
    });
}
$list = $query->orderBy('id', 'desc')->paginate($limit)

输出goods列表包含所属的商家和商家所属的公司

php 复制代码
$builder = Goods::where('status',1);
if($request->filled('type')){
   $builder->where('type',$request->type);
}
//两种都可以
//$builder->with(['business.company'])->get();
$list = $builder->with(['business'=>function($query){
    $query->with('company');
}])->get(); 
相关推荐
林多7 分钟前
【Android】 GPU过度绘制实现原理
android·gpu·性能·实现原理·过度绘制·overdraw
X56619 分钟前
Python Django怎么处理404_关闭DEBUG模式并自定义配置全局404与500友好错误重定向页面
jvm·数据库·python
薄荷椰果抹茶10 分钟前
手机端Obsidian安装与同步全攻略
android
m0_7485548111 分钟前
golang如何集成Etcd配置中心_golang Etcd配置中心集成方法
jvm·数据库·python
醇氧11 分钟前
CentOS 7安装 mysql-8.0.27-1.el7.x86_64.rpm 安装包
android·mysql·centos
qwert103715 分钟前
深入解析Python标识符:定义、规则、规范与实践指南
开发语言·数据库·python
Jetev15 分钟前
Golang怎么做API网关_Golang API网关教程【总结】
jvm·数据库·python
m0_6908258215 分钟前
Go语言如何发GET请求_Go语言HTTP GET请求教程【总结】
jvm·数据库·python
2301_7838486517 分钟前
HTML怎么处理右键菜单_HTML contextmenu自定义(已废弃)替代方案【指南】
jvm·数据库·python
DolphinDB智臾科技19 分钟前
工业时序数据库 DolphinDB:以云边一体化平台驱动边缘计算落地
数据库·边缘计算·时序数据库