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(); 
相关推荐
带电的小王2 分钟前
WhisperKit: Android 端测试 Whisper -- Android手机(Qualcomm GPU)部署音频大模型
android·智能手机·whisper·qualcomm
梦想平凡15 分钟前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
TianyaOAO25 分钟前
mysql的事务控制和数据库的备份和恢复
数据库·mysql
Ewen Seong37 分钟前
mysql系列5—Innodb的缓存
数据库·mysql·缓存
元争栈道40 分钟前
webview和H5来实现的android短视频(短剧)音视频播放依赖控件
android·音视频
码农老起1 小时前
企业如何通过TDSQL实现高效数据库迁移与性能优化
数据库·性能优化
阿甘知识库1 小时前
宝塔面板跨服务器数据同步教程:双机备份零停机
android·运维·服务器·备份·同步·宝塔面板·建站
元争栈道2 小时前
webview+H5来实现的android短视频(短剧)音视频播放依赖控件资源
android·音视频
夏木~2 小时前
Oracle 中什么情况下 可以使用 EXISTS 替代 IN 提高查询效率
数据库·oracle
W21552 小时前
Liunx下MySQL:表的约束
数据库·mysql