【问题标题】:How to make Entity/Table subquery Inner Join on itself - NativeQuery/DQL Symfony 2如何使实体/表子查询自身内部加入 - NativeQuery/DQL Symfony 2
【发布时间】:2017-02-11 10:52:31
【问题描述】:

我有这个查询(工作正常)。

$sql = 'select * from ps_message p1 INNER JOIN (SELECT MAX(p2.id) as max_id FROM ps_message p2 GROUP BY p2.thread_id) as max_table on p1.id = max_table.max_id';

我想将它转换为我的 Symfony2 项目。

我已尝试使用 createQueryBuilder() 构建 DQL 查询,并使用 ResultSetMapping()/ResultSetMappingBuilder() 构建本机查询,但还没有成功。

附:使用 ResultSetMapping() 我无法使关系字段正常工作。我尝试过修改 addJoinedEntityResult() 等。:

$rsm = new ResultSetMapping();
$rsm->addEntityResult('BaseBundle:PsMessage', 'p1');
$rsm->addFieldResult('p1', 'id', 'id');
$rsm->addFieldResult('p1', 'message_text', 'messageText');
$rsm->addFieldResult('p1', 'message_type', 'messageType');
$rsm->addFieldResult('p1', 'receiver_message_status', 'receiverMessageStatus');
$rsm->addFieldResult('p1', 'sender_message_status', 'senderMessageStatus');
$rsm->addFieldResult('p1', 'created_date', 'createdDate');
$rsm->addFieldResult('p1', 'modified_date', 'modifiedDate');

$rsm->addFieldResult('t1', 'thread_id', 'thread_id'); //Error
$rsm->addFieldResult('u', 'sender_id', 'sender'); //Error
$rsm->addFieldResult('t', 'thread_id', 'thread'); //Error
$rsm->addFieldResult('p2', 'thread_id', 'thread'); //Error

$sql = 'select * from ps_message p1 INNER JOIN (SELECT MAX(p2.id) as max_id FROM ps_message p2 GROUP BY p2.thread_id) as max_table on p1.id = max_table.max_id';
$query = $em->createNativeQuery($sql, $rsm);

【问题讨论】:

    标签: php mysql symfony doctrine-orm dql


    【解决方案1】:

    我使用两个查询解决了这个问题。

    这个得到了线程的最新消息:

    $messages_max = $em->createQueryBuilder()
    ->select('max(m.id) as id')
    ->from('BaseBundle:PsMessage', 'm')
    ->groupBy('m.thread')
    ->getQuery()
    ->getResult();
    

    这个显示所有线程:

    $qb = $em->createQueryBuilder()
    ->select('message')
    ->from('BaseBundle:PsMessage', 'message')
    ->where('message.receiver = :id')
    ->orWhere('message.sender = :id')
    ->andWhere('message.id in (:maxIds)')
    ->orderBy('message.modifiedDate', 'desc')
    ->setParameter('id', $userId)
    ->setParameter('maxIds', $messages_max);
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-04-14
      • 2012-11-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多