2

所以这是场景:

我有两个表,问题和项目。

一个项目可以有多个问题,一个问题可以恰好是一个项目。

由于Issue是多对一的,你必须定义它吗?

因为我知道在项目模型中我有:

public function relations()
{
    return array(
    'issues' => array(self::HAS_MANY, 'Issue', 'project_id'),
    'users' => array(self::MANY_MANY, 'User', 'tbl_project_user_assignment(project_id, user_id)'),
    );
}

对于问题模型,我只有外键:

public function relations()
{
    // NOTE: you may need to adjust the relation name and the related
    // class name for the relations automatically generated below.
    return array(
        'requester' => array(self::BELONGS_TO, 'User', 'requester_id'),
        'owner' => array(self::BELONGS_TO, 'User', 'owner_id'),
        'project' => array(self::BELONGS_TO, 'Project', 'project_id'),
    );
}

我猜任何关系都不需要定义?

先感谢您。

顺便说一句,我正在写敏捷 Yii 书,最后我问了自己这个问题。AR 类中有一个独一选项(http://www.yiiframework.com/doc/guide/database.arr)。

但是由于某种原因,这种情况是可选的吗?

4

2 回答 2

5

它有助于我将 BELONGS_TO 和 HAS_ONE 之间的区别视为“外键存储在哪里”?如果项目模型存储了“Issue_Id”,那么潜在的问题可能有很多项目。您使用 HAS_ONE 关系来说明即使问题可以有很多项目,它也只有一个。

但是,更常见的情况是如果您将 Project_Id 存储在问题模型中(我假设您是)。然后你必须使用 BELONGS_TO 关系。看来您已经正确定义了上面的关系。

有人在这里发布了一个与 Yii 关系相关的类似问题,我帮助回答了: yii - using relationship HAS_ONE to get data from the related table to display in list page

至于您对“需要”定义关系的关注,您不需要“定义”任何关系。您可以编写自己的 SQL 查询来做同样的事情。ActiveRecord 关系只是一个方便的东西,可以让查询相关记录变得更简单。如果您永远不会查找问题的项目,那么您“不需要”定义“项目”BELONGS_TO 关系。

在没有真正看到您的数据库结构的情况下,在我看来您已经正确设置了所有内容。您现在可以轻松地进行 $issue->project 和 $project->issues “惰性”关系查询,充分利用 Relational Active Record 的强大功能。干杯,祝项目好运!

于 2010-08-28T16:43:26.860 回答
1

在您的问题模型中,您已经将关系指定为 BELONGS_TO 项目模型。

我也刚拿到新的 yii 书。这对我帮助很大!

快乐编码:)

于 2010-08-28T16:37:18.757 回答