Несколько запросов данных Cake Paginator Query Result
Я получил следующий результат после использования Paginate в Cake:
array(
(int) 0 => array(
'DestinationPhoto' => array(
'id' => '1',
'name' => 'picture.jpg',
'destination_id' => '2'
),
'Destinations' => array(
'id' => '2',
'country_id' => '2'
),
'DestinationIdiom' => array(
'id' => '3',
'name' => 'TestName-1',
'description' => 'TestDescription',
'idiom' => 'English',
'destination_id' => '2'
)
),
(int) 1 => array(
'DestinationPhoto' => array(
'id' => '1',
'name' => 'picture.jpg',
'destination_id' => '2'
),
'Destinations' => array(
'id' => '2',
'country_id' => '2'
),
'DestinationIdiom' => array(
'id' => '4',
'name' => 'TestName-2',
'description' => 'TestDescription-2',
'idiom' => 'Spanish',
'destination_id' => '2'
)
)
)
Поскольку кажется, что я получил несколько экземпляров "DestinationPhoto", "Destination", вызванных разными "DestinationIdiom", в одном и том же результате, возможно ли объединить оба "DestinationIdiom", чтобы они отображались как один и тот же результат для paginator? лайк
array(
(int) 0 => array(
'DestinationPhoto' => array(
'id' => '1',
'name' => 'huehuehuehuh.jpg',
'destination_id' => '2'
),
'Destinations' => array(
'id' => '2',
'country_id' => '2'
),
'DestinationIdiom' => array(
(int) 0 => array(
'id' => '3',
'name' => 'TestName-1',
'description' => 'TestDescription',
'idiom' => 'English',
'destination_id' => '2'
)
(int) 1 => array(
'id' => '3',
'name' => 'TestName-2',
'description' => 'TestDescription',
'idiom' => 'Spanish',
'destination_id' => '2'
)
)
)
)
В контроллере DestinationPhoto у меня есть следующее:
$this->paginate = array(
'fields'=>array('DestinationPhoto.*','Destinations.*','DestinationIdiom.*'),
'joins' => array(
array(
'table' => 'destinations',
'alias'=>'Destinations',
'type' => 'LEFT',
'conditions' => '`DestinationPhoto`.`destination_id` = `Destinations`.`id`'
),
array(
'table' => 'destination_idioms',
'alias'=>'DestinationIdiom',
'type' => 'LEFT',
'conditions' => '`DestinationIdiom`.`destination_id` = `Destinations`.`id`'
)
),
'limit' => 20
);
1 ответ
Решение
Используйте соглашение о наименовании моделей. Сделай это Destination
вместо Destinations
,
Свяжите ассоциацию модели во время выполнения, как указано ниже:
$this->paginate = array(
'joins' => array(
array(
'table' => 'destinations',
'alias'=>'Destination',
'type' => 'LEFT',
'conditions' => '`DestinationPhoto`.`destination_id` = `Destinations`.`id`'
)),
'limit' => 20,
'recursive' => '2'
);
$this->DestinationPhoto->Destination->bindModel(array('hasMany' => array('DestinationIdiom' => array('className' => 'DestinationIdiom',
'foreignKey' => 'destination_id'))), false);
$result = $this->paginate('Destination');
pr($result);
die;