我遇到了 Doctrine Paginator 的问题。
在我的存储库中,我有一个检索特定数据集的功能。我为此使用查询构建器:
{myEntityRepository}->createQueryBuilder($alias)
为了仅选择特定字段,我使用以下内容:
if (count($selectFields) > 0) {
$qb->resetDQLPart('select');
foreach ($selectFields as $selectField) {
$qb->addSelect($alias . '.' . $selectField);
}
}
当我像这样检索整个集合时,这很好用:
$query = $qb->getQuery();
$data = $query->getResult(AbstractQuery::HYDRATE_ARRAY);
但是当我使用分页器时它失败了:
$paginator = new Paginator($qb, $fetchJoinCollection = false);
$total = $paginator->count(),
$data = $paginator->getQuery()->getResult(AbstractQuery::HYDRATE_ARRAY)
我得到错误:
并非所有标识符属性都可以在 ResultSetMapping 中找到:relationID
\vendor\doctrine\orm\lib\Doctrine\ORM\Query\Exec\SingleSelectExecutor.php(38)
问题:为什么当我只选择特定字段时分页器会失败?
我忽略了什么吗?还是我一起做错了?