thinkphp6.0模型篇值一对多关联查询

一、hasMany模式

1、hasMany模式,适合主表关联附表,适合一堆多查询,具体设置方式如下

return $this->hasMany(stumenu::class,'外键','主键');

2、使用stumenu()方法模式可以进一步进行数据的筛选

$user->stumenu()->where('id','>',1)->select();

3、使用has()方法查询关联附表的主表内容,比如大于等于2条的主表记录

Students::has('stumenu',['uname'=>1]->select())

4、使用hasWhere()方法,查询关联附表筛选后记录

Students::hasWhere('stumenu',['sex'=>'男'])->select();

5、使用save()方法和saveAll()进行关联新增和批量关联新增

$user = UserModel::find(19); 
$user->profile()->save(['hobby'=>'测试喜好', 'status'=>1]); 
$user->profile()->saveAll([ 
['hobby'=>'测试喜好', 'status'=>1], 
['hobby'=>'测试喜好', 'status'=>1] 
]);

6、使用together()方法可以删除主表内容时,将附表关联的内容全部删除

$user=Students::with('stumenu')->find(227);
$user->together(['stumenu'])->delete();
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值