gpt4 book ai didi

php - Yii2 - Gii 模型关系 - 为什么函数名称后有 0?

转载 作者:搜寻专家 更新时间:2023-10-31 21:07:35 26 4
gpt4 key购买 nike

在查看其他人的代码、指南、教程等时,我还没有在网上看到过这个。

当我用 Gii 生成模型时,关于关系的函数后面都有一个零。


示例:

class Benefit extends \yii\db\ActiveRecord
{
// truncated Yii Model code...

public function getType0()
{
return $this->hasOne(BenefitTypes::className(), ['id' => 'type']);
}
}

BenefitTypes 是一个 ID 到名称的映射:

id | name
---------------
1 => Federal
2 => Non-Profit

在“benefit”表中,它有一个名为“type”的列,该列与“benefit_types”表的“id”列相关。

虽然我应该能够(在/views/benefit/index.php 中)'type.name',但它也不起作用。它将列名更改为“Type Name”并在数据表中放入“(not set)”...

例子:

<?= DetailView::widget([
'model' => $model,
'attributes' => [
'id',
'somevalue',
'type.name',
],
]) ?>

这是怎么回事,为什么它不像预期的那样行事?


更新

我开始认为关系函数名称的 0 后缀,即:getType0,是由于“类型”在表中用作列名以避免重复或混淆。不过我找不到这个记录,所以想对此有一个明确的答案。

我将函数名称更改为 getTypeRelation()。然后在 index.php View 中,对于 detailview 小部件,使用“typeRelation.name”并通过关系返回名称就好了。

最佳答案

你的想法是正确的。关系名称的生成由函数 generateRelationName() 完成.

protected function generateRelationName($relations, $table, $key, $multiple)
{
if (!empty($key) && substr_compare($key, 'id', -2, 2, true) === 0 && strcasecmp($key, 'id')) {
$key = rtrim(substr($key, 0, -2), '_');
}
if ($multiple) {
$key = Inflector::pluralize($key);
}
$name = $rawName = Inflector::id2camel($key, '_');
$i = 0;
while (isset($table->columns[lcfirst($name)])) {
$name = $rawName . ($i++);
}
while (isset($relations[$table->fullName][$name])) {
$name = $rawName . ($i++);
}
return $name;
}

Yii 使用相关表的名称作为关系名称。如果你有一个与相关表同名的列,一个数字将被附加到关系中以避免由于 Yii 处理魔法函数而造成的混淆。如果在与同一个表相关的单个表中有两列或更多列,也会发生这种情况,例如与表相关的列 create_user_idupdate_user_iddelete_user_id user 将产生名为 useruser0user1 的关系。

对于您的示例,建议您将外键字段命名为其他名称,例如 type_idtypeId。 Yii 会正确处理这些。当您有多个列与同一个表相关时,另一种选择是重命名函数。

关于php - Yii2 - Gii 模型关系 - 为什么函数名称后有 0?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29886756/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com