При использовании моделей ORM от Kohana 3, какой лучший способ получить данные из полей связанных моделей? Например, у меня есть сотрудник, у которого есть одна компания, и у меня много заданий. Как я могу получить данные из полей модели и модели (ов) компании (т. Е. В отношениях has_one и has_many)?Kohana 3: получение связанных данных из модели ORM
РЕДАКТИРОВАТЬ: в соответствии с запросом, приведены модели, о которых идет речь.
пользователя Модель
class Model_User extends ORM {
protected $_table_name = 'user';
protected $_primary_key = 'id';
protected $_primary_val = 'username';
protected $_has_many = array(
'task' => array(
'model' => 'task',
'foreign_key' => 'user',
),
);
protected $_belongs_to = array(
'company' => array(
'model' => 'company',
'foreign_key' => 'company'
),
);
Задача Модель
class Model_Task extends ORM {
protected $_table_name = 'tasks';
protected $_primary_key = 'id';
protected $_primary_val = 'name';
protected $_belongs_to = array(
'project' => array(
'model' => 'project',
'foreign_key' => 'project'
),
'user' => array(
'model' => 'user',
'foreign_key' => 'user'
),
);
Компания Модель
class Model_Company extends ORM {
protected $_table_name = 'companies';
protected $_primary_key = 'id';
protected $_primary_val = 'name';
protected $_has_many = array(
'user' => array(
'model' => 'user',
'foreign_key' => 'company'
),
);
}
кода Бросив Ошибку, От контроллера
$users = ORM::factory('user')->find_all();
$list = array();
foreach($users as $user) {
$list[$user->id] = array(
'username' => $user->username,
'email' => $user->email,
'company' => $user->company->name //error:Trying to get property of non-object
)
}
А, я вижу: 'foreign_key' => 'company' в Model_User. Вы не можете использовать как внешний ключ, так и отношения с теми же именами. – biakaveron