簡體   English   中英

Zend_Db_Select:使用JOIN的

[英]Zend_Db_Select: Working with JOIN's

我有這個查詢:

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的聯接,但是它給了我數組錯誤

$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的解決方案thanx。 我只是在這里發布解決方案,以防其他人陷入像這樣的問題中。 解決方案是:

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

您正在使用Zend_Db_Table_Select對象。 默認情況下,那些啟用了完整性檢查,並且不能選擇表外的數據。

您可以通過在選擇對象之前添加-> setIntegrityCheck(false)到選擇對象來關閉它。

您可以在手冊中的 “選擇API->高級用法”下閱讀更多信息

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM