我有以下表格:
users { id, name }
events { id, name }
user_events { id, date, user_id, event_id }
user_summaries { id, user_id, event_id, qty }
表user_events
存储所有用户事件(在不同时间有许多相同类型)并user_summaries
存储每个用户发生的每种类型事件的数量。前者只得到INSERT
查询,而后者主要是查询UPDATE
。
当然,两者user_events
都有user_summaries
外键链接users
和events
表。我想在我的 Kohana 模型中表示这种关系。我有外键的经验,但这是我第一次使用 Kohana 和 ORM 的方法,我不确定如何在那里定义我的模型来表示这些关系。
我想要能够做的基本上是这样的:
// I'm able to do this.
$user = ORM::factory('user', 1);
$user_events = $user->events->find_all();
$user_summaries = $user->usersummaries->find_all();
// I'm able to do this, too.
$event = ORM::factory('event', 1);
$event_users = $event->users->get_all();
// I don't know how to be able to do this:
$user_event = ORM::factory('userevent', 1);
$user_details = $user_event->user->find();
$event_details = $user_event->event->find();
我当前的模型如下所示:
# classes/model/user.php
class Model_User extends ORM
{
protected $_has_many = array(
'scores' => array(),
'usersummaries' => array(),
);
}
# classes/model/event.php
class Model_Event extends ORM
{
protected $_has_many = array(
'scores' => array(),
'usersummaries' => array(),
);
}
# classes/model/userevent.php
class Model_Userevent extends ORM
{
protected $_belongs_to = array(
'user' => array(),
'event' => array(),
);
}
# classes/model/usersummary.php
class Model_Usersummary extends ORM
{
protected $_belongs_to = array(
'user' => array(),
'event' => array(),
);
}
目前调用:
$user_event = ORM::factory('userevent', 1);
$user_details = $user_event->user->find();
总是返回表中的第一个用户users
,即使userevent
有不同的 user_id。我想我需要改变一些东西,Model_userevent
但我会在一些帮助下使用。
注意。我正在使用 Kohana 3.0.8。