naming tables in many to many relationships laravel(在多对多关系 Laravel 中命名表)
问题描述
我担心多对多 Laravel 关系中的自动命名表.
I concerned about auto naming tables in many-to-many Laravel relationship.
例如:
Schema::create('feature_product', function (Blueprint $table) {}
当表名改为:
Schema::create('product_feature', function (Blueprint $table) {}
我的关系有问题.
product_feature
有什么问题?
推荐答案
Laravel 对数据透视表的命名约定是用蛇形大小写的模型名称按字母顺序用下划线分隔.因此,如果一个模型是 Feature
,另一个模型是 Product
,那么数据透视表将是 feature_product
.
Laravel's naming convention for pivot tables is snake_cased model names in alphabetical order separated by an underscore. So, if one model is Feature
, and the other model is Product
, the pivot table will be feature_product
.
您可以随意使用任何您想要的表名称(例如 product_feature
),但是您需要在关系中指定数据透视表的名称.这是使用 belongsToMany()
函数的第二个参数完成的.
You are free to use any table name you want (such as product_feature
), but you will then need to specify the name of the pivot table in the relationship. This is done using the second parameter to the belongsToMany()
function.
// in Product model
public function features()
{
return $this->belongsToMany('AppFeature', 'product_feature');
}
// in Feature model
public function products()
{
return $this->belongsToMany('AppProduct', 'product_feature');
}
您可以在文档中阅读有关多对多关系的更多信息一>.
You can read more about many to many relationships in the docs.
这篇关于在多对多关系 Laravel 中命名表的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在多对多关系 Laravel 中命名表


基础教程推荐
- Yii2 - 在运行时设置邮件传输参数 2022-01-01
- 主题化 Drupal 7 的 Ubercart “/cart"页 2021-01-01
- 如何在数学上评估像“2-1"这样的字符串?产生“1"? 2022-01-01
- php中的foreach复选框POST 2021-01-01
- php中的PDF导出 2022-01-01
- Web 服务器如何处理请求? 2021-01-01
- php 7.4 在写入变量中的 Twig 问题 2022-01-01
- 使用 scandir() 在目录中查找文件夹 (PHP) 2022-01-01
- 将变量从树枝传递给 js 2022-01-01
- PHPUnit 的 Selenium 2 文档到底在哪里? 2022-01-01