У меня есть следующие таблицы базы данных:
products
********
id
title
artist_id
artists
*******
id
profile
rating
person_id
people
******
id
full_name
Со следующими ассоциациями модели:
Product Model
*************
public $belongsTo = array(
'Artist' => array(
'className' => 'Artist'
'foreignKey' => 'artist_id'
)
);
Artist Model
************
public $belongsTo = array(
'Person' => array(
'className' => 'Person'
'foreignKey' => 'person_id'
)
);
public $hasMany = array(
'Product' => array(
'className' => 'Product'
'foreignKey' => 'product_id'
)
);
Person Model
************
public $hasOne = array(
'Artist' => array(
'className' => 'Artist'
'foreignKey' => 'person_id'
)
);
Я настроил каждую из трех моделей для использования поведения Containable, используя:
public $actsAs = array('Containable');
Когда я использую следующее, чтобы получить детали продукта вместе с именем художника:
$this->Product->find('first', array('conditions' => array('Product.id' => $id), 'contain' => 'Person.full_name'))
, я получаю предупреждение:
Model "Product" is not associated with model "Person"
И я толькополучить информацию о продукте, т. е. не имя исполнителя.Почему это происходит?