【问题标题】:Create one to many relation in FuelPHP在 FuelPHP 中创建一对多关系
【发布时间】:2012-12-09 12:01:55
【问题描述】:

我有 3 个模型:客户端、任务和任务状态(用于为每个客户端匹配任务)。
模型_任务

protected static $_properties = array(
        'id',
        'name',
        'created_at',
        'updated_at',
    );

Model_Client

protected static $_properties = array(
        'id',
        'name',
        'created_at',
        'updated_at',
    );

模型_任务状态

protected static $_properties = array(
        'id',
        'client',
        'task',
        'created_at',
        'updated_at',
    );

我在 Model_Task 中添加了以下内容

protected static $_has_many = array(
        'taskstatuses' => array(
            'key_from' => 'id',
            'model_to' => 'Model_Taskstatus',
            'key_to' => 'task',
            'cascade_save' => true,
            'cascade_delete' => false,
        )
    );

Model_Client

protected static $_has_many = array(
        'taskstatuses' => array(
            'key_from' => 'id',
            'model_to' => 'Model_Taskstatus',
            'key_to' => 'client',
            'cascade_save' => true,
            'cascade_delete' => false,
        )
    );

模型_任务状态

protected static $_belongs_to = array(
        'client' => array(
            'key_from' => 'client',
            'model_to' => 'Model_Client',
            'key_to' => 'id',
            'cascade_save' => true,
            'cascade_delete' => false,
        ),
        'task' => array(
            'key_from' => 'task',
            'model_to' => 'Model_Task',
            'key_to' => 'id',
            'cascade_save' => true,
            'cascade_delete' => false,
        )
    );

我希望 taskstatus 将客户端字段链接到客户端模型,并将任务字段链接到任务模型,如果用户插入的任务的值不在客户端或任务模型中(通过 id),则会出现错误。但它不起作用(我仍然可以将客户端和任务表中不存在的客户端 id 和任务 id 的值添加到 clientstatus 中。

【问题讨论】:

  • 什么不起作用? “不起作用”不是错误消息!描述你在做什么以及你想要发生什么。
  • 我希望 taskstatus 中的客户端和任务字段必须链接到客户端和任务模型中的 id 字段。我刚刚添加了 2 个客户端和 2 个任务。我希望如果我插入值为 client = 40 和 task = 13 的 taskstatus,例如,会发生一个错误,告诉我我不能这样做。但实际上我仍然可以插入客户端和任务值>2的taskstatus,这是我没想到的。

标签: php database-design orm fuelphp


【解决方案1】:

如果您坚持使用Model convention,以下将正常工作:

class Model_Task extends \Orm\Model
{
    protected static $_belongs_to = array(
        'client'
    );

    protected static $_properties = array(
        'id',
        'name',
        'client_id',
        'created_at',
        'updated_at'
    );
}

class Model_Client extends \Orm\Model
{
    protected static $_has_many = array(
        'task'
    );

    protected static $_properties = array(
        'id',
        'name',
        'created_at',
        'updated_at'
    );
}

要获得客户的任务,您只需:

$client = Model_Client::find(1);

foreach($client->task as $task)
{
    /* do something with each $task */
}

编辑: 这样您就可以避免在客户端/任务之间有不必要的表/模型,从而迫使您将有效任务添加到现有客户端。此外,如果您想在 Client/Task 之间建立 一对多 关系,使用 Model_Taskstatus 将允许您将相同的任务分配给不同的客户端,这不是您想要的。

您应该查看Has Many 文档。

【讨论】:

  • 实际上我有一个适用于所有客户的标准清单。因此,我必须跟进 1 个客户,哪些任务已完成,哪些未完成。因此我认为关系不是客户端和任务之间的关系,而是客户端/任务和任务状态之间的关系。我已经检查了 Has Many Documentation,但不明白“建立和打破 has-many 关系”(它应该放在哪里 - 控制器,模型?以什么方法?“Model_Comment::find”中的 6 是什么意思(6)")。抱歉,我对 FuelPHP 完全陌生,而且文档对我来说似乎不够具体。
  • 在我发布的foreach() 迭代示例中,您可以检查与客户端关联的每个任务的状态。除了 Has Many 文档之外,您还应该检查 Creating models 和所有 ORM documentationModel_Comment::find(6) 表示您要获取 id = 6 的 Model_Comment
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-07-09
  • 1970-01-01
  • 1970-01-01
  • 2022-10-25
相关资源
最近更新 更多