这是我要显示用户历史记录的功能。为此,我需要显示用户的当前信用及其信用记录。
这就是我想要做的:
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
,从示例中选取),那么语法非常简单:
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
完全相同。
如果没有可用的关联,则查询如下所示
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,
),
// ...
)
本文向大家介绍举例说明如何在页面中添加数学公式?相关面试题,主要包含被问及举例说明如何在页面中添加数学公式?时的应答技巧和注意事项,需要的朋友参考一下 http://jartto.wang/2018/07/08/perfect-math/
问题内容: 我有以下型号: 我想查询所有未分配志愿者的部门。我可以使用以下查询进行操作: 有没有一种更像django的方式做到这一点,还是我应该只使用原始sql? 问题答案: 您可以通过遵循查找中的向后关系来执行此操作。 以下是有关“跨多值关系”查询的文档:https : //docs.djangoproject.com/en/stable/topics/db/queries/#spanning-
我正在尝试为我的RecolyerView添加滑动功能。我正在跟随这个链接添加刷卡。https://github.com/nikhilpanju/recyclerviewenhanced/blob/master/recyclerviewenhanced/src/main/java/com/nikhilpanju/recyclerviewenhanced/recyclertouchlistener.j
问题内容: 这是我在数据库中查询一些单词的方法 我正在使用mysql,我想获得符合条件的随机行,我在查询中使用rand()的顺序。 我发现这个类似的问题基本上表明,由于在理论中不支持ORDER BY RAND,因此可以将主键随机化。但是,在我的情况下无法做到这一点,因为我有一个搜索条件和一个where子句,因此并非每个主键都可以满足该条件。 我还找到了一个代码段,建议您使用OFFSET来随机化行,
我正在尝试将通用数学库导入我的Android Studio项目。我将文件commons-math3-3.6.1.jar文件放在libs文件夹中,并在gradle文件中我有这一行: 但我有一个错误:` 错误:(32,0)提供了字符串模块符号“commons-math3-3.6.1”。“jar”无效。示例注释:“org。gradle:gradle核心:2.2','组织。mockito:mockito核
本文向大家介绍如何在JDBC中将数据插入CachedRowSet?说明?,包括了如何在JDBC中将数据插入CachedRowSet?说明?的使用技巧和注意事项,需要的朋友参考一下 CachedRowSet是断开连接的行集的基本实现。它连接到数据源,从中读取数据,与数据源断开连接并处理检索到的数据,重新连接到数据源并写入修改。 创建一个CachedRowSet 您可以使用RowSetFactory的