首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在多对多关系中命名表

在多对多关系中命名表
EN

Stack Overflow用户
提问于 2016-01-20 18:26:45
回答 1查看 35.2K关注 0票数 45

我关心多对多Laravel关系中的自动命名表。

例如:

代码语言:javascript
复制
Schema::create('feature_product', function (Blueprint $table) {}

将表名更改为:

代码语言:javascript
复制
Schema::create('product_feature', function (Blueprint $table) {}

我的关系出了点问题。

product_feature怎么了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-20 18:40:10

Laravel对数据透视表的命名约定是snake_cased模型名称按字母顺序排列,中间用下划线分隔。因此,如果一个模型是Feature,另一个模型是Product,那么数据透视表将是feature_product

您可以自由使用所需的任何表名称(例如product_feature),但随后需要在关系中指定数据透视表的名称。这是使用belongsToMany()函数的第二个参数完成的。

代码语言:javascript
复制
// in Product model
public function features()
{
    return $this->belongsToMany('App\Feature', 'product_feature');
}

// in Feature model
public function products()
{
    return $this->belongsToMany('App\Product', 'product_feature');
}

你可以阅读更多关于many to many relationships in the docs的内容。

票数 101
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34897444

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档