dqhdz04240 2010-10-24 02:53 采纳率: 0%
浏览 72
已采纳

Zend_Db_Select:使用JOIN的

I have this query:

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

Now, this is my JOIN using Zend_Db_Select but it gives me array error

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

My error:

Exception information:

Message: Select query cannot join with another table

Does anyone know what I did wrong?

UPDATE / SOLUTION:

I've found the solution thanx to Eran. I just post the solution here in case anyone else is stuck on a problem like this one. The solution is:

$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条回答 默认 最新

  • dsh12544 2010-10-24 02:58
    关注

    You are using a Zend_Db_Table_Select object. Those by default have integrity check enabled and cannot select data that is outside of their table.

    You can turn it off by adding -> setIntegrityCheck(false) to the select object before querying with it.

    You can read more about it in the manual under Select API -> Advanced usage

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 WPF RichTextBox格式化大量文本卡顿如何解决
  • ¥15 什么设备可以研究OFDM的60GHz毫米波信道模型
  • ¥15 不知道是该怎么引用多个函数片段
  • ¥15 pip install后修改模块路径,import失败,需要在哪里修改环境变量?
  • ¥15 爬取1-112页所有帖子的标题但是12页后要登录后才能 我使用selenium模拟登录 账号密码输入后 会报错 不知道怎么弄了
  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型