laravel 多对多关联模型CURD详解

1、laravel官方文档中给出了一种用户-角色(User-Role)关系的例子。在这个例子中,一个用户可能与多个角色对应,反过来同理,一个角色也可能对应多个用户。官方说的比较简单,这里详细介绍一下。

  • 一个用户可以有多个不同的角色;
  • 一个角色会拥有各种不同的用户;

现在已最简单的数据解构为例进行说明:

  • 角色数据表roles :id、name
  • 用户数据表users : id、name
  • 角色-用户数据表role_user : role_id、user_id

在这个场景中,role_user数据表,就是我们所要说明的pivot表(透视表,及本文的主要说明对象),首先做一下几点说明:

  • 关联表名称:关联表的命名满足一下两点:①需包含相关联的单表的表名;②以下划线_链接相关联表名;③通常以字母先后顺序来确定相关联表名的先后顺序;如本例中关联表可叫做role_user而不是user_role或者其他名字;
  • 创建关联表:创建关联表,一般常见一个简单的命令php artisan make:migrationphp artisan make:migration:pivot.
  • 关联表键名:通常情况下,每个关联表需要有两个外键字段,每个外键对应一张外联表,在我们的商店-商品场景中,这两个外键分别是role_id、user_id;当然如果你喜欢你也可以添加更多的字段,但那种情况下,你需要添加更多的关系,这种情况我们稍后会进一步说明。

 

2、创建数据表

 

php artisan make:model --migration Model/Roles

修改文件如下:

Schema::create('roles', function (Blueprint $table) {

    $table->increments('id');

    $table->string('name');

    $table->timestamps();

});

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值