Контейнерное поведение CakePHP не работает, как ожидалось - PullRequest
0 голосов
/ 09 ноября 2011

У меня есть следующие таблицы базы данных:

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"

И я толькополучить информацию о продукте, т. е. не имя исполнителя.Почему это происходит?

1 Ответ

2 голосов
/ 09 ноября 2011

Это происходит потому, что вы вызываете операцию find для модели Product, а Person не напрямую относится к Product, а косвенно, по отношению к Artist.В этом случае ваш массив contain должен выглядеть примерно так:

$this->Product->find('first', array(
    'conditions' => array('Product.id' => $id), 
    'contain' => array('Artist' => 'Person.full_name')
));

Это вернет результат, подобный

array(
    [Product] => array(...),
    [Artist] => array(
        [Person] => array(
             'full_name' => '...'
        )
    )
)
...