Zend_Db_Select: работа с JOIN - PullRequest
       3

Zend_Db_Select: работа с JOIN

2 голосов
/ 24 октября 2010

У меня есть этот запрос:

SELECT
    groups.name
    categories.name,
    categories.label
FROM
    groups
JOIN
    categories
ON
    (categories.group1 = groups.id
OR
    categories.group2 = groups.id)
AND
    groups.label = :section
AND
    categories.active = 1

Теперь, это мой JOIN, использующий Zend_Db_Select, но он дает мне ошибку массива

$select->from($dao, array('groups.name', 'categories.name', 'categories.label'))
       ->join(array('categories', 'categories.group1 = groups.id OR categories.group2 = groups.id'))
       ->where('groups.label = ?', $group)
       ->where('categories.active = 1');

Моя ошибка:

Информация об исключении:

Сообщение: выбранный запрос не может объединиться с другой таблицей

Кто-нибудь знает, что я сделал не так?

ОБНОВЛЕНИЕ / РЕШЕНИЕ:

Я нашел решение, спасибо Эрану.Я просто выкладываю решение здесь на тот случай, если кто-то застрянет на такой проблеме, как эта.Решение:

$db = Zend_Registry::get('db');
$dao = new Default_Model_Db_CategoryDao('db');
$select = $dao->select();

$select->setIntegrityCheck(false)
       ->from(array('c' => 'categories'), array('name', 'label'))
       ->join(array('g' => 'groups'), 'c.group1 = g.id OR c.group2 = g.id', 'g.label')
       ->where('g.label = ?', $group)
       ->where('c.active = 1');

return $dao->fetchAll($select);

1 Ответ

4 голосов
/ 24 октября 2010

Вы используете объект Zend_Db_Table_Select. По умолчанию включена проверка целостности, и они не могут выбирать данные, находящиеся за пределами их таблицы.

Вы можете отключить его, добавив -> setIntegrityCheck (false) к выбранному объекту, прежде чем запрашивать его.

Подробнее об этом можно прочитать в руководстве в разделе Выбор API -> Расширенное использование

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