使用带条件的内连接的 Doctrine 查询生成器

2023-12-31

我想使用 Doctrine 的查询构建器构建以下 SQL:

select c.*
from customer c
join phone p
on p.customer_id = c.id
and p.phone = :phone
where c.username = :username

首先我尝试过

$qb->select('c')
    ->innerJoin('c.phones', 'p', Join::ON, $qb->expr()->andx(
        $qb->expr()->eq('p.customerId', 'c.id'),
        $qb->expr()->eq('p.phone', ':phone')
    ))
    ->where('c.username = :username');

但我收到以下错误

Error: expected end of string, got 'ON'

然后我尝试了

$qb->select('c')
    ->innerJoin('c.phones', 'p')
    ->where('c.username = :username')
    ->andWhere('p.phone = :phone');

这似乎有效。但是,有人知道第一次尝试出了什么问题吗?我想让第一个起作用,因为它更接近于 SQL 的结构。

注意:我知道我们也可以使用 Doctrine 编写本机 mysql 或 dql,但我更喜欢查询生成器。

EDIT:下面是整个代码

namespace Cyan\CustomerBundle\Repository;

use Cyan\CustomerBundle\Entity\Customer;
use Doctrine\ORM\EntityRepository;
use Doctrine\ORM\Query\Expr\Join;

class CustomerRepository extends EntityRepository
{
    public function findCustomerByPhone($username, $phone)
    {
        $qb = $this->createQueryBuilder('c');

        $qb->select('c')
            ->innerJoin('c.phones', 'p', Join::ON, $qb->expr()->andx(
                $qb->expr()->eq('p.customerId', 'c.id'),
                $qb->expr()->eq('p.phone', ':phone')
            ))
            ->where('c.username = :username');

//        $qb->select('c')
//            ->innerJoin('c.phones', 'p')
//            ->where('c.username = :username')
//            ->andWhere('p.phone = :phone');

        $qb->setParameters(array(
            'username' => $username,
            'phone' => $phone->getPhone(),
        ));

        $query = $qb->getQuery();
        return $query->getResult();
    }
}

我要回答我自己的问题。

  1. innerJoin 应该使用关键字“WITH”而不是“ON”(Doctrine 的文档 [13.2.6. Helper 方法] 不准确;[13.2.5. Expr 类] 是正确的)
  2. 无需在连接条件中链接外键,因为它们已在实体映射中指定。

因此,以下内容对我有用

$qb->select('c')
    ->innerJoin('c.phones', 'p', 'WITH', 'p.phone = :phone')
    ->where('c.username = :username')
    ->setParameter('phone', $phone)
    ->setParameter('username', $username);

or

$qb->select('c')
    ->innerJoin('c.phones', 'p', Join::WITH, $qb->expr()->eq('p.phone', ':phone'))
    ->where('c.username = :username')
    ->setParameter('phone', $phone)
    ->setParameter('username', $username);;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用带条件的内连接的 Doctrine 查询生成器 的相关文章

随机推荐

  • 该语句没有返回结果集。 Java错误

    我正在尝试使用 JDBC 从 java 表中删除数据 首先 我计算行数并确保表不为空 然后截断数据 这是我正在使用的代码 Class forName com microsoft sqlserver jdbc SQLServerDriver
  • jdbc 驱动程序“org.gjt.mm.mysql.Driver”的用途是什么?

    在接手一位同事的项目后 我注意到他使用 org gjt mm mysql Driver 作为 MySQL 5 的 jdbc 驱动程序 而不是更常见的 com mysql jdbc Driver 它们都包含在我在 Maven 中心找到的驱动程
  • 员工 ID 的标准正则表达式

    我需要员工的标准正则表达式就像 EMP015 015EMP EMP 015 E 015 EMP 015 EMP VIS EMP 056 基本上应该允许 or or or 字母数字字符之间 状况 第一个字符不应该是 or or or 员工 I
  • 如何按单元格中的第一个字符过滤范围?

    如果 cell Text 以 A 开头 我想按 column1 过滤 multipleColumnRange rng01 Columns 1 AutoFilter Field 1 Criteria1 firstCharacter A Vis
  • 与正常模式下正确设置的回车符相比,为什么 fprintf 在文本模式下的行为不同?

    下面的问题与其说是一个问题 不如说是一个好奇心 我绊倒了这个问题 https stackoverflow com q 6536599 2605073 提供了两个似乎相同的不同答案 但他们不是 这让我思考 想象一个system调用会回显两行
  • 在 Windows 机器上运行 python 与在 Linux 上运行 [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 我对学习 python 很感兴趣 但我的 Linux 技能很糟糕 我想使用 python 和 django 开发一个中型到大型 Web
  • 获取 R 中向量每 10 步的平均值[重复]

    这个问题在这里已经有答案了 我有一个值向量 1 0 0 4 1 0 0 1 1 1 0 1 0 0 2 0 0 17 1 2 0 2 0 1 1 1 0 1 1 0 0 0 0 0 33 0 2 0 4 2 0 0 1 1 0 0 0 1
  • Graphite只会显示过去24小时的数据

    以下是过去 24 小时的统计数据显示 在 Graphite Composer 中 以下是 过去 14 天 的统计数据显示 那里没有太大区别 我无法说服 Graphite 显示过去 24 小时内任何时间段的任何数据 以下是来自的相关条目sto
  • Google API Gateway:在标头中提供 API 密钥

    我正在尝试设置 Google API Gateway 以使用调用者在标头中发送的 API 密钥 我的 api 配置 yaml 如下所示 securityDefinitions api key header type apiKey name
  • PyLint 无法识别 cv2 成员

    我正在 opencv 项目上运行 pylint 并且在 VS 代码中收到许多有关成员不存在的 pylint 错误 示例代码 import cv2 cv2 imshow 得到的错误 不过 代码运行正确 没有任何错误 版本 pylint 1 8
  • GIT Xcode - 更改原点

    如何更改 GIT 存储库中的原始 url 我不想添加新的存储库 我想换旧的 请帮帮我 我找到了添加新选项但不更改现有选项的选项 Thanks 我认为你不能从 XCode4 中做到这一点 就像许多其他事情一样 Do git remote se
  • 使用下拉菜单创建虚线图

    您好 我有一个 excel 文件 如下所示 其中有三个不同的服务器 A B C 我正在尝试构建一个带有下拉菜单的仪表板应用程序 可以选择所需的服务器并显示每个服务器的 CPU 使用情况和内存使用情况的图表 我尝试从 Dash 官方网站修改以
  • 使用按钮清除多选(角primeng涡轮表)

    是否可以通过按钮远程清除多选 或多个多选 我正在使用 primeng multiselect 和 Turbo table 我已经多次看到这个问题 但没有选择答案 以下是我的多选 span span
  • 如何在yii2中进行ajax调用?

    在 yii 1 14 版本中我们使用 CHtml ajax链接 对于 ajax 调用 在 yii2 中怎么样 你可以像这样创建一个ajax链接 Html a Your Link name controller action title gt
  • 缺少带有 .otf 的内容类型标头字体

    我使用 Laravel 框架 但是在 chrome 控制台中发生了这个错误并且font family不工作 无法加载资源 服务器响应状态为 500 缺少 Content Type 标头 In css font face font famil
  • 使用 PyDrive 上传 XLSX 并将其转换为 Google Sheets

    我正在尝试将 xlsx 文件上传到 Google 云端硬盘 我可以上传它 但是 当我们尝试在云端硬盘中打开同一文件时 必须使用 Google 表格打开它 因此 它会创建一个同名的新文件并消耗驱动器空间 我想我需要在上传时更改 MimeTyp
  • 不同IPC机制的使用

    我是一名 C 程序员 我想知道一个实时场景 我们可以使用不同的 IPC 机制 例如 PIPE 命名 共享内存 我大致知道在哪里可以使用套接字和消息队列 但对于 PIPE Named PIPE 和共享内存我没有任何想法 这只是为了了解不同的
  • 如何将elasticquery转换为kibana URL

    我正在使用 kibana 6 仪表板来显示可视化 我有一个如下所示的弹性查询 它需要传入 kibana 仪表板 URL query bool minimum should match 1 should match phrase jt tax
  • 带 VCL 样式的 Inno Setup 语言选择器

    有没有办法将语言选择器 Inno Setup 与VCL样式一起使用 如何 出现 选择安装语言 对话框之前叫做 因此您无法加载对话框的皮肤 作为解决方法 您可以实现自己的 语言 对话框 并从InitializeSetup 这样自定义对话框就会
  • 使用带条件的内连接的 Doctrine 查询生成器

    我想使用 Doctrine 的查询构建器构建以下 SQL select c from customer c join phone p on p customer id c id and p phone phone where c usern