Условия поиска с моделью hasMany

У меня 4 модели:

Товар ------hasMany ---->Подробности

Предмет ------hasMany ---->Избранное

Предмет ------hasMany ---->Категория

Как мне найти все Предметы, у которых есть Favourite.member _id = '8' и Category.item _category _id = '1'

Вот мое отношение модели Item:

public $hasMany = array(                
    'Detail' => array(
        'className' => 'Detail',
        'foreignKey' => 'item_id',
        'dependent' => true,
        'conditions' => '',
        'order' => 'created DESC',          
    ),      
    'Category' => array(
        'className' => 'Category',
        'foreignKey' => 'item_id',
        'dependent' => true,
        'conditions' => '',
        'order' => 'created DESC',          
    ),
    'Favorite' => array(
        'className' => 'Favorite',
        'foreignKey' => 'item_id',
        'dependent' => true,
        'conditions' => '',
        'order' => 'created DESC',          
    )

);

Я использовал этот запрос ()и все в порядке:

$this->set('test',$this->Item->query("SELECT items.*
                                        FROM items, categories, favourites
                                        WHERE items.id = items_item_categories.item_id
                                        AND items.id = favorites.item_id
                                        AND categories.item_category_id = 1 AND favourites.member_id = 8"));

Но Мне не нравится использовать query (), и я меняю его на find (), и это кажется не очень хорошим:

$this->set('test',$this->Item->find('all', array(
                                                'contain'=>array(
                                                    'ItemDetail',
                                                    'Category'=>array('conditions'=>array('Category.item_category_id'=>1)),
                                                    'Favorite'=>array('conditions'=>array('Favorite.member_id'=>8)));
5
задан Tam Huynh 27 April 2012 в 06:09
поделиться