这是我要显示用户历史记录的功能。为此,我需要显示用户的当前信用及其信用记录。
这就是我想要做的:
public function getHistory($users) { $qb = $this->entityManager->createQueryBuilder(); $qb->select(array('a','u')) ->from('Credit\Entity\UserCreditHistory', 'a') ->leftJoin('User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id') ->where("a.user = $users ") ->orderBy('a.created_at', 'DESC'); $query = $qb->getQuery(); $results = $query->getResult(); return $results; }
但是,我得到这个错误:
[语法错误]第0行,列98:错误:预期的Doctrine \ ORM \ Query \ Lexer :: T_WITH,设置为“ ON”
编辑 :我在join子句中用“ WITH”替换了“ ON”,现在我看到的只是joined列中的1个值。
如果您在指向用户的属性上具有关联(例如Credit\Entity\UserCreditHistory#user,从示例中选取),那么语法非常简单:
Credit\Entity\UserCreditHistory#user
public function getHistory($users) { $qb = $this->entityManager->createQueryBuilder(); $qb ->select('a', 'u') ->from('Credit\Entity\UserCreditHistory', 'a') ->leftJoin('a.user', 'u') ->where('u = :user') ->setParameter('user', $users) ->orderBy('a.created_at', 'DESC'); return $qb->getQuery()->getResult(); }
由于您要在此处对合并结果应用条件,因此使用LEFT JOIN或JOIN完全相同。
LEFT JOIN
JOIN
如果没有可用的关联,则查询如下所示
public function getHistory($users) { $qb = $this->entityManager->createQueryBuilder(); $qb ->select('a', 'u') ->from('Credit\Entity\UserCreditHistory', 'a') ->leftJoin( 'User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id' ) ->where('u = :user') ->setParameter('user', $users) ->orderBy('a.created_at', 'DESC'); return $qb->getQuery()->getResult(); }
这将产生一个结果集,如下所示:
array( array( 0 => UserCreditHistory instance, 1 => Userinstance, ), array( 0 => UserCreditHistory instance, 1 => Userinstance, ), // ... )