laravel使用 面向对象的方式绑定多对多的关系

创建model文件,并且一起创建migration文件:

php   artisan  make:model Habit  -m

创建多对多的中间表的方法:

php artisan make:migration create_habit_user_table --create=habit_user

设计habit_user:

$table->unsignedInteger('user_id');

$table->unsignedInteger('habit_id');

模型中定义多对多:

user模型:

public function habits(){

  return $table->belongsToMany(Habit::class);

}

/*

belongsToMany参数说明:

第一个参数是 第二个Model 
第二个参数是 关系表名 
第三个参数是 第一个Model在关系表中的外键ID 
第四个参数是 第二个Model在关系表中的外键ID

*/

Habit模型:

public function users(){

  return $this->belongsToMany(User::class);

}

 

实现多对多关系:

第一种方法:attach(不会删除之前的数据,只会把新添加的数据加上去)

//通过面向对象的方式绑定文章和标签:
$label1=\App\Label::create(['name'=>'Python']);
$label2=\App\Label::create(['name'=>'Java']);
$article=\App\Article::first();
$article->labels()->attach([
$label1->id,
$label2->id
]);
dd($article->labels);

第二种方法:sync(使用sync会和数据库同步,只会保留我们填写的id项,其他的项都会删除掉)
$label1=\App\Label::create(['name'=>'Python']);
$label2=\App\Label::create(['name'=>'Java']);
$article=\App\Article::first();
$article->labels()->sync([
$label1->id,
$label2->id
]);
dd($article->labels);

解绑的方法使用detach,只需要传入需要解绑的数据id就可以了

转载于:https://www.cnblogs.com/yiweiyihang/p/10459056.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值