【发布时间】: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