【问题标题】:Zend_Db_Select: Working with JOIN'sZend_Db_Select:使用 JOIN
【发布时间】:2011-04-29 17:59:40
【问题描述】:

我有这个问题:

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

现在,这是我使用 Zend_Db_Select 的 JOIN,但它给了我数组错误

$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');

我的错误:

异常信息:

消息:选择查询无法加入 另一张桌子

有谁知道我做错了什么?

更新/解决方案:

我找到了解决 Eran 的方法。我只是在这里发布解决方案,以防其他人遇到这样的问题。解决办法是:

$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);

【问题讨论】:

    标签: php sql zend-framework select join


    【解决方案1】:

    您正在使用 Zend_Db_Table_Select 对象。默认情况下,它们启用了完整性检查,并且无法选择其表之外的数据。

    您可以通过在使用它进行查询之前将 -> setIntegrityCheck(false) 添加到选择对象来关闭它。

    您可以在 Select API -> Advanced usage 下阅读更多相关信息 in the manual

    【讨论】:

    • 我添加了 ->setIntegrityCheck(false),现在我得到:Mysqli prepare error: Unknown column 'groups.name' in 'field list'
    • 列数组中不要使用表名,取自原始Zend_Db_Table对象
    猜你喜欢
    • 2012-08-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多