当前位置: 首页 > 面试题库 >

如何在学说中加入左派?

辛盛
2023-03-14
问题内容

这是我要显示用户历史记录的功能。为此,我需要显示用户的当前信用及其信用记录。

这就是我想要做的:

 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 JOINJOIN完全相同。

如果没有可用的关联,则查询如下所示

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的