CakePHP нумерация с моделями HABTM

У меня есть некоторые проблемы с созданием нумерации страниц с отношениями 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 я хочу разбить на страницы все элементы в 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...

Есть идеи?

3 ответа

Решение

Я был в состоянии заставить это работать несколько, но решение не кажется очень легким.

$items = $this->paginate(
    $this->Request->ToLocation->Item,
    array(
        "Item.id IN ("
        . "SELECT item_id FROM items_locations "
        . "WHERE location_id = " . $locationId
        . ")"
    )
);

После 3 дней поисков я нашел путь

var $paginate = array('Post'=>array('group'=>'Post.id'));

Рекомендуется добавить группу, потому что иногда мы получим дублирующиеся сообщения в разных категориях

$this->Post->bindModel(array('hasOne'=>array('CategoriesPost')), false);
$out = $this->paginate('Post', array('CategoriesPost.category_id'=>array(1,4,7,6)));

Добавьте false, чтобы использовать модель связывания для всех запросов, а не только для следующих

Чтобы разбить на страницы HABTM, вам нужно временно связать модель соединения hasOne с моделью, которую вы разбили на страницы:

// prepare to paginate Item
$this->Item->bindModel(array('hasOne'=>array('ItemsLocation')));
$contain['ItemsLocation']=array();
$conditions[]=array('ItemsLocation.location_id'=>$locationId);
$order = array('Item.created' => 'desc'); // set order
...
$items = $this->paginate('Item', compact('conditions','contain','order'));
Другие вопросы по тегам