laravel使用 面向对象的方式绑定多对多的关系
2024-10-12 04:22:50
创建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就可以了
最新文章
- OCP考点实战演练02-日常维护篇
- H2 database的使用
- iOS开发——新特性OC篇&;IOS9 系统新特性
- 我终于理解了LISP『代码即数据|数据即代码』的含义
- 降维(一)----说说主成分分析(PCA)的源头
- 使用jquery处理ajax返回XML
- C# MVC 自学笔记—5 添加模型
- gulp填坑记(二)——gulp多张图片自动合成雪碧图
- $HOME
- Python Trick —— 命令行显示
- linux top指令信息表示
- 恭喜PBD终于有了自己的物理解释和模型
- centos6.9NAT网络模式
- mybatis3 date 的处理
- JS打开新窗口,子窗口操作父窗口
- PHP中=>;是什么意思
- css3统一元素的宽和高
- [Go] panic 和 recover
- tomcat在conf/Catalina/localhost目录下配置项目路径
- selenium测试(Java)--元素操作(五)