Tôi có 4 mô hình:Tìm điều kiện với mô hình hasMany
mục ------ hasMany ----> Chi tiết
mục ------ hasMany ----> yêu thích
mục ------ hasMany ----> thể loại
Làm thế nào tôi có thể tìm thấy tất cả các mục có Favourite.member_id = '8' và Category.item_category_id = '1'
đây là quan hệ mô hình mặt hàng của tôi:
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',
)
);
tôi đã sử dụng truy vấn này() và nó là ok:
$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"));
Nhưng tôi không thích sử dụng truy vấn(), và tôi thay đổi nó thành find(), và có vẻ như không tốt:
$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)));
Cảm ơn bạn đã trả lời tôi, nhưng kết quả trả lại một số mảng trống, tôi không biết tại sao. –
Hãy thử $ this-> Item-> Favorite-> find ('all', array ('conditions' => array ('Favorite.member_id' => 8), 'contains' => mảng ('ItemDetail', 'Category ',' Yêu thích '))); – CROWD
Lỗi được ném: Mô hình "Yêu thích" không được liên kết với mô hình "Danh mục" và "ItemDetail" –