我正在寻找我在zend应用程序中面临的问题的解决方案,
我在我的 sql 中使用 zf 1.12 和 php 5.3,
这是我的查询,它在我的 SQL 中完美运行
SELECT usermaster.*, (select count(projecttouser.u_id) from projecttouser where
usermaster.id=projecttouser.u_id ) as proj,
(select count(tasktotarget.assigned_to) from tasktotarget where
usermaster.id=tasktotarget.assigned_to ) as target,
(select count(tasktotarget.assigned_to) from tasktotarget where
usermaster.id=tasktotarget.assigned_to AND tasktotarget.is_active = 1 ) as active
from usermaster group by usermaster.id
这给出了我想要但在我的 sql 中的完美输出
现在我的问题是我必须在 zend 框架环境查询中转换该查询,
这与我的 sql 格式有些不同,
我尝试了以下方法,
$psub=$this->select()
->setIntegrityCheck(false)
->from(array('p'=>'projecttouser'),array('count(p.u_id) as count'))
->join(array('i'=>'usermaster'),'p.u_id=i.id')
->where('i.id=p.u_id');
$tsub=$this->select()
->setIntegrityCheck(false)
->from(array('t'=>'tasktotarget'),array('count(t.assigned_to) as tcount'))
->where('usermaster.id=tasktotarget.assigned_to');
$tasub=$this->select()
->setIntegrityCheck(false)
->from(array('ta'=>'tasktotarget'),array('count(ta.assigned_to) as tacount'))
->where('usermaster.id=tasktotarget.assigned_to AND tasktotarget.is_active = 1 ');
$sql=$this->select()
->setIntegrityCheck(false)
->from(array('u'=>'usermaster',$psub,$tsub,$tasub))
->group('u.id')
->order($order_by . ' ' . $order)
->where('u.is_delete=false');
$resultSet = $this->fetchAll($sql);
return $resultSet;
所以,如果有人可以帮助我创建和格式化查询,那将非常有帮助