我有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。