Cakephp, соединяющий таблицы через опцию поиска, не работает - PullRequest
1 голос
/ 29 октября 2011

Я пытаюсь присоединить таблицу Users к моей текущей таблице hasMany Through, в которой есть идентификаторы интереса и модели пользователя.

Ниже приведен запрос поиска с параметрами:

$params = array(
                    'fields' => array('*', 'COUNT(DISTINCT(InterestsUser.interest_id)) as interest_count'),
                    'limit' => 15,
                    'recursive' => -1,
                    'offset' => $offset,
                    'conditions' => array('InterestsUser.interest_id' => $conditions),
                    'group' => array('InterestsUser.user_id'),
                    'order' => array('interest_count DESC', 'InterestsUser.user_id ASC', 'InterestsUser.interest_id ASC'),
                        'joins' => array(
                            array('table' => 'users',
                                'alias' => 'User',
                                'type' => 'LEFT',
                                'conditions' => array(
                                    'User.id' => 'InterestsUser.user_id',
                                )
                            )
                        )
                    );

            $results = $this->InterestsUser->find('all', $params);

Это возвращает таблицу InterestsUser в порядке, но не возвращает никаких значений для таблицы Users. Возвращает только имена полей.

Что может быть не так?

UPDATE: Хорошо, выше генерируется ниже SQL, который я получил из журнала sql источников данных Cake:

SELECT *, COUNT(DISTINCT(InterestsUser.interest_id)) as interest_count 
FROM `interests_users` AS `InterestsUser` 
LEFT JOIN users AS `User` ON (`User`.`id` = 'InterestsUser.user_id')  
WHERE `InterestsUser`.`interest_id` IN (3, 2, 1)  
GROUP BY `InterestsUser`.`user_id`  
ORDER BY `interest_count` DESC, `InterestsUser`.`user_id` ASC, `InterestsUser`.`interest_id` ASC  
LIMIT 15

Почему пользовательские таблицы возвращают NULL только для всех полей?

UPDATE:

ОК, я попробовал ниже, но это работает нормально ... Что мне здесь не хватает !! ??

SELECT * , COUNT( DISTINCT (
interests_users.interest_id
) ) AS interest_count
FROM interests_users
LEFT JOIN users ON ( users.id = interests_users.user_id ) 
WHERE interests_users.interest_id
IN ( 1, 2, 3 ) 
GROUP BY interests_users.user_id
ORDER BY interest_count DESC 
LIMIT 15

1 Ответ

1 голос
/ 29 октября 2011

Синтаксис массива для условий соединения должен быть следующим:

array('User.id = InterestsUser.user_id')

в отличие от array('User.id' => 'InterestsUser.user_id'). Подробнее см. http://book.cakephp.org/view/1047/Joining-tables.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...