如何使用Native Query和ResultSetMapping排除双向关系?

时间:2014-12-18 09:09:02

标签: symfony doctrine-orm nativequery bidirectional-relation sqlresultsetmapping

我有2个实体,User和Customer,具有OneToOne双向关系。用户实体还与Invoice实体具有双向关系:

class User implements UserInterface
{
    /**
     * @ORM\OneToOne(targetEntity="Evo\UserBundle\Entity\Customer", mappedBy="user", cascade={"persist", "remove"})
     * @Type("Evo\UserBundle\Entity\Customer")
     */
    protected $customer;

    /**
     * @ORM\OneToMany(targetEntity="Evo\BackendBundle\Entity\Invoice", mappedBy="user", cascade={"remove"})
     */
    protected $invoices;
}

class Customer
{
    /**
     * @ORM\OneToOne(targetEntity="Evo\UserBundle\Entity\User", inversedBy="customer")
     * @ORM\JoinColumn(name="account", nullable=false)
     */
    protected $user;
}

现在,我想使用NativeQuery和ResultSetMapping检索用户及其客户关系,但仅此而已。我试过了

$sql = "SELECT a.id, a.identifier, c.id AS customer_id, c.email, c.firstname, c.lastname
    FROM account a
    INNER JOIN customer c ON c.account = a.id
    WHERE c.email = 'user@mail.com'";

$rsm = new ResultSetMapping();
$rsm->addEntityResult('Evo\UserBundle\Entity\User', 'u');
$rsm->addFieldResult('u', 'id', 'id');
$rsm->addFieldResult('u', 'identifier', 'username');

$rsm->addJoinedEntityResult('Evo\UserBundle\Entity\Customer' , 'c', 'u', 'customer');
$rsm->addFieldResult('c', 'customer_id', 'id');
$rsm->addFieldResult('c', 'email', 'email');
$rsm->addFieldResult('c', 'firstname', 'firstname');
$rsm->addFieldResult('c', 'lastname', 'lastname');

$query = $this->_em->createNativeQuery($sql, $rsm);

$users = $query->getResult();

return $users;

但这会让用户及其所有双向关系回归:

array(1) {
  [0]=>
  object(stdClass)#1370 (33) {
    ["__CLASS__"]=>
    string(26) "Evo\UserBundle\Entity\User"
    ["id"]=>
    string(5) "38425"
    ["invoices"]=>
    array(77) {
      [0]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [1]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [2]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [3]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [4]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [5]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [6]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [7]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [8]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
      [9]=>
      string(32) "Evo\BackendBundle\Entity\Invoice"
    }
    ["customer"]=>
    object(stdClass)#3083 (87) {
      ["__CLASS__"]=>
      string(30) "Evo\UserBundle\Entity\Customer"
      ["id"]=>
      string(5) "38553"
      ["user"]=>
      string(26) "Evo\UserBundle\Entity\User"
      ["email"]=>
      string(12) "rien@rien.fr"
      ["lastname"]=>
      string(13) "RAVIER (TEST)"
      ["firstname"]=>
      string(7) "Jacques"
    }
    ["username"]=>
    string(12) "rien@rien.fr"
  }
}

我想在返回的数据中删除这些Invoice关系。 我应该用ResultSetMapping做什么?

注意:由于某个特定原因,我无法在此功能上使用经典DQL,我确实需要使用NativeQuery。

0 个答案:

没有答案