Zend DB选择嵌套连接

时间:2010-10-15 21:37:34

标签: database zend-framework join nested zend-db-select

我正在尝试使用zend db select实现以下查询:

SELECT `uac`.`uid`, `u`.`uid`, `g`.`groupid`, `g`.`packageid` 
FROM `user_has_data` AS `uac` 
INNER JOIN `users` AS `u` ON u.uid = uac.uid 
LEFT JOIN (`user_in_group` AS `uig` 
  INNER JOIN `groups` AS `ag` ON (ag.groupid = uig.groupid) AND (ag.packageid = 2) 
 ) AS `g` ON uac.uid = g.uid
WHERE (uac.dataid = '3') AND (u.uname LIKE 'test%')
GROUP BY `u`.`uid`

我得到了以下内容,但在尝试将嵌套连接转换为zend结构时卡住了:

$select = $db->select()->from(array('uac' => 'user_has_data'), array('uac.uid'))
->join(array('u' => 'users'), 'u.uid = uac.uid', array('uid', 'uname'))
->joinLeft(array('uig' => 'user_in_groups'), 'uig.uid = uid', array('agid' => 'uig.groupid'))
->join(array('ag' => 'groups'), '(ag.agid = uig.groupid) AND ( ag.packageid = '.$packageid.')', array('packageid'))
->where('uac.dataid = ?', $dataid)
->where('(u.uname LIKE ?)', $value)
->group('u.uid');

是否有可能将给定的sql查询转换为适合zend db select的结构?我需要一个select对象在paginator中进一步处理,所以如果这不可能,我必须进行直接的SQL查询。

2 个答案:

答案 0 :(得分:0)

我不相信你可以使用Zend_Db_Select进行嵌套连接。最好的办法是创建自己的paginator适配器(比你想象的要容易,查看Select一个)并自己管理SQL的LIMIT部分。

答案 1 :(得分:0)

我知道问题已经过时了,但我认为人们仍然可以从这个问题的正确答案中受益。

嵌套连接与

相同
 SELECT * FROM `user_in_group` AS `uig` 
 INNER JOIN `groups` AS `ag` ON (ag.groupid = uig.groupid) AND (ag.packageid = 2) 

所以这应该可以正常工作。

$subquery = $db->select()
->from(array('uig' => 'user_in_groups'),'*')
->joinInner(array('ag'=>'groups'),'(ag.groupid = uig.groupid) and (ag.packegeid = 2)',array('*'));

$select = $db->select()->from(array('uac' => 'user_has_data'), array('uac.uid'))
->join(array('u' => 'users'), 'u.uid = uac.uid', array('uid', 'uname'))
->joinLeft('g'=>$subquery), 'uac.uid = g.uid', array('g.groupid', 'g.packageid'))
->where('uac.dataid = ?', $dataid)
->where('(u.uname LIKE ?)', $value)
->group('u.uid');