1

doctrine query builder で [Semantical Error] がスローされる問題があります。構築しようとしているクエリは次のとおりです:-

   $query = $this->_em->createQueryBuilder()
       ->select('r, m')
       ->from('Ajfit\Entity\TicketReply', 'r')
       ->join('r.mailFk', 'm')
       ->where('r.ticketFk = :ticket')
       ->orderBy('m.dt', 'desc')
       ->setParameter('ticket', $ticket)
       ->getQuery();

    $paginator =  new Paginator($query);
    return $paginator->getIterator(); //////////blows up here!

スローされるエラーは次のとおりです。

  [Semantical Error] line 0, col 64 near 'm WHERE r.ticketFk': Error: Class Ajfit\Entity\TicketReply has no association named mailFk 

エラーが参照しているエンティティは次のとおりです:-

名前空間 Ajfit\Entity;

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Persistence\PersistentObject;
use Doctrine\Common\Collections\ArrayCollection;

/**
 * Ajfit\Entity\TicketReply
 *
 * @ORM\Table(name="ticket_reply")
 * @ORM\Entity(repositoryClass="Ajfit\Repository\TicketReply")
 * @ORM\HasLifecycleCallbacks
 */
 class TicketReply extends \Doctrine\Common\Persistence\PersistentObject
 {
    /**
     * @ORM\Id
     * @ORM\Column(name="mail_fk", type="integer")
     * @ORM\ManyToOne(targetEntity="Ajfit\Entity\Mail", inversedBy="replies")
     * @ORM\JoinColumn(name="mail_fk", referencedColumnName="pk")
     */
    protected $mailFk;

    /**
     * @ORM\Id
     *  @ORM\Column(name="ticket_fk", type="integer")
     * @ORM\ManyToOne(targetEntity="Ajfit\Entity\Ticket", inversedBy="replies")
     * @ORM\JoinColumn(name="ticket_fk", referencedColumnName="pk")
     */
    protected $ticketFk;

   /**
    * @var integer $rating
    *
    * @ORM\Column(name="rating", type="integer")
    */
    protected $rating;

 }

エラーの詳細は、TicketReply エンティティに mailFk 関連付けがないことを示していますが、関連付けられているため、querybuilder を作成している理由に問題がありますか?

ありがとうアンドリュー

4

1 に答える 1

2

と注釈$mailFkの両方があります。列の注釈は、格納されたリレーションには使用できません。Doctrine は、.ColumnManyToOneColumnManyToOne

@ORM\Column注釈を削除します。

/**
 * @ORM\Id
 * @ORM\ManyToOne(targetEntity="Ajfit\Entity\Mail", inversedBy="replies")
 * @ORM\JoinColumn(name="mail_fk", referencedColumnName="pk")
 */
protected $mailFk;

についても同じことを行います$ticketFk

于 2012-08-24T19:49:36.270 に答える