我在使用HABTM关系创建分页时遇到了一些问题。首先,表和关系:CakePHP分页与HABTM模型
requests (id, to_location_id, from_location_id)
locations (id, name)
items_locations (id, item_id, location_id)
items (id, name)
因此,请求具有地理位置的请求从来和位置的请求会到。对于这个问题,我只关心“到”位置。
Request --belongsTo--> Location* --hasAndBelongsToMany--> Item
(* as "ToLocation")
在我的RequestController中,我想分页处理Request的ToLocation中的所有项目。
// RequestsController
var $paginate = array(
'Item' => array(
'limit' => 5,
'contain' => array(
"Location"
)
)
);
// RequestController::add()
$locationId = 21;
$items = $this->paginate('Item', array(
"Location.id" => $locationId
));
,这是失败的,因为它是产生这个SQL:
SELECT COUNT(*) AS count FROM items Item WHERE Location.id = 21
我无法弄清楚如何使实际使用的$paginate
的“遏制”的说法...
任何想法?
这是唯一为我工作,具有HABTM表中的非约定字段名的方式。 – 2017-03-17 13:10:16