我有这个带有子查询的查询。
SELECT * FROM
(SELECT module_id FROM an_modules AS m LIMIT 20 OFFSET 0) AS m
LEFT JOIN an_module_sites AS ms ON (m.module_id = ms.module_id)
如何使用DBAL像这样构建子查询?
这似乎行不通。
$qb->select('*')
->from(
$qb->select('module_id')
->from($this->Db->getTableName('modules'), 'm')
, 'm')
->leftJoin('m', $this->Db->getTableName('module_sites'), 'ms', 'm.module_id = ms.module_id');
$stmt = $qb->execute();
$result = $stmt->fetchAll();
最佳答案
我最近需要这样做来实现分页/排序助手。作为其中的一部分,我将采用由我的模型执行的查询生成器,并通常计算它在不受限制的情况下将生成的总行数。
要跨平台,我不能使用 rowCount
并且潜在的分组意味着我不能只更改选择中的字段 - 所以最好的选择是删除限制并将其计为子查询。这是我想出的:
<?php
$totalResults = $qb->getConnection()->createQueryBuilder()
->select('COUNT(*)')
->from(
'('
.$qb
->setFirstResult(null)
->setMaxResults(null)
->resetQueryPart('orderBy')
->getSQL()
.')',
'tmp')
->execute()
->fetch(\PDO::FETCH_COLUMN);
我不确定 doctrine ORM 是如何处理这个问题的,但至少在纯 DBAL 中这似乎是可行的。
关于mysql - 如何使用 DBAL 查询构建器来构建这个子查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33869759/