我首先想知道 DQL 中是否允许嵌套查询。我发现至少部分是(见这里)。所以我想知道他们是否可以做我需要的。
情况如下:我有一张表ProjectNotification
,其中包含所有项目和所有用户的所有通知。然后,我有一个UserXNotification
表,其中存储给定用户已阅读的通知的 ID。我希望能够提取每个项目的未读通知总数(不是由当前用户发起的)。以下查询有效(没有内部选择)。但是这个给出了错误。
$query = $em->createQuery(
'SELECT IDENTITY (n.project), COUNT(n.id)
FROM AppBundle:ProjectNotification n
WHERE n.project IN (:projectIDs)
AND n.user <> :user
AND n.id NOT IN (
SELECT uxn.projectNotification
FROM AppBundle:UserXNotification uxn
WHERE uxn.user = :user
AND uxn.read = false
)
GROUP BY n.project
')->setParameter('projectIDs', $projectIDs)
->setParameter('user', $user);
$notifQueryResult = $query->getResult();
具体的错误是:
QueryException: [Semantical Error] line 0, col 354 near 'projectNotification': Error: Invalid PathExpression. Must be a StateFieldPathExpression.
为了完整起见,这里是 UsersXNotifications 实体:
class UserXNotification
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\ManyToOne(targetEntity="User")
*/
protected $user;
/**
* @ORM\ManyToOne(targetEntity="ProjectNotification")
*/
protected $projectNotification;
/**
* @ORM\Column(type="boolean")
*/
protected $readStatus;
这是 ProjectNotification 实体
class ProjectNotification
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
// SOME IRRELEVANT FIELDS
/**
* @ORM\ManyToOne(targetEntity="Project")
*/
protected $project;
/**
* @ORM\ManyToOne(targetEntity="User")
*/
protected $user;
实际上我写的查询的第一个版本有SELECT uxn.projectNotification.id
,SELECT uxn.projectNotification
但它给了我这个错误:
QueryException: [Semantical Error] line 0, col 378 near 'id': Error: Class AppBundle\Entity\UserXNotification has no field or association named projectNotification.id
我也试过:
...
AND n NOT IN (
SELECT uxn.projectNotification
无济于事。我知道内部查询正在检索对象,这就是我尝试最后一个的原因。这种情况下的错误是:
QueryException: [Semantical Error] line 0, col 355 near 'projectNotification': Error: Invalid PathExpression. Must be a StateFieldPathExpression.
我希望它是可行的,而无需编写本机 sql和水合物:/
有什么提示吗?