创建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就可以了

最新文章

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

热门文章

  1. 安卓BLE测试apk
  2. 20180519001 - DataTable Group by功能参考
  3. 【Mongo】安装并配置副本集
  4. [c/c++] programming之路(26)、结构体
  5. vscode技巧之代码规范editorconfig
  6. JS getBoundingClientRect()
  7. sed命令替换文件的内容【学习笔记】
  8. SQL 删除数据 的所有用法
  9. 基于Ocelot的gRpcHttp网关
  10. 【python 3】 字典方法操作汇总