0

この SQL ステートメントを使用すると、すべてのユーザーから最新のメッセージを取得できます。

SELECT  m1.*
FROM    message AS m1
INNER JOIN user
   AS u1
   ON m1.sender_id = u1.user_id
INNER JOIN (
   SELECT   sender_id,
   MAX(dateSent) MaxDate
   FROM     message
   WHERE receiver_id = 4
   GROUP BY sender_id
) AS m2
ON m1.sender_id = m2.sender_id
AND m1.datesent = m2.MaxDate;

これらは、私の Zend Framework 2 アプリケーションのエンティティです。

まず、メッセージを受け取りました。ユーザーはメッセージを別のユーザーに送信できます。

/**
 * @ORM\Entity
 * @ORM\Table(name="message")
 */
class Message
{
/**
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 * @ORM\Column(type="integer")
 */
private $id;

/**
 * @ORM\ManyToOne(targetEntity="Application\Entities\User", inversedBy="messagesSent")
 * @ORM\JoinColumn(referencedColumnName="user_id")
 */
private $sender;

/**
 * @ORM\ManyToOne(targetEntity="Application\Entities\User", inversedBy="messagesReceived")
 * @ORM\JoinColumn(referencedColumnName="user_id")
 */
private $receiver;

/**
 * @ORM\Column(type="string", length=1024)
 */
private $message;

そしてここの User エンティティ:

/**
 * @ORM\Entity
 * @ORM\Table(name="user")
 */
class User
{
/**
 * @var int
 * @ORM\Id
 * @ORM\Column(type="integer")
 * @ORM\GeneratedValue(strategy="AUTO")
 */
protected $user_id;

そのSQL を DQLに変換しようとしたところ、次のようになりました。

SELECT  m1.*
FROM    Application\Entities\Message AS m1
INNER JOIN Application\Entities\User AS u1
    WITH m1.sender_id = u1.user_id
INNER JOIN (
    SELECT  sender_id,
    MAX(dateSent) MaxDate
    FROM    Application\Entities\Message
    WHERE receiver_id = 4
    GROUP BY sender_id
) AS m2
WITH m1.sender_id = m2.sender_id
AND m1.datesent = m2.MaxDate;

実行すると、Doctrine からエラーが発生します。

[Semantical Error] line 0, col 206 near '(
      ': Error: Class '(' is not defined.

私は何を間違えましたか?

4

1 に答える 1

0

サブクエリは、(私が知る限り) DQL (from this ) のドクトリンでは使用できません。クエリビルダーを書くことができますか?

public function innerJoin($join, $alias = null, $conditionType = null, $condition = null);

リファレンスを参照

于 2014-01-13T07:57:29.850 に答える