tengo 4 modelo:Encuentra condiciones con el modelo hasMany
artículo ------ hasMany ----> Detalle
artículo ------ hasMany ----> favoritas
artículo ------ hasMany ----> Categoría
¿Cómo puedo encontrar todo elemento que tiene Favourite.member_id = '8' y Category.item_category_id = '1'
Aquí está mi relación de modelo de artículo:
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',
)
);
que utiliza esta consulta() y que está bien:
$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"));
Pero no me gusta el uso de consulta(), y lo cambio en find(), y parece que no es bueno:
$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)));
Gracias por responderme, pero el resultado devuelve una matriz vacía, no sé por qué. –
Pruebe $ this-> Item-> Favorite-> find ('all', array ('condiciones' => array ('Favorite.member_id' => 8), 'contienen' => array ('ItemDetail', 'Category ','Favorito'))); – CROWD
Error arrojado: el modelo "Favorito" no está asociado con el modelo "Categoría" y "Detalles del artículo" –