Symfony 原则2本机查询从联接实体中选择
注意:这是特定的本机查询 我有两个相关实体“CrmBusinessPartner”和“RefCountry”以及“crmbusinesspartnersepository”存储库 CrmBusinessPartner实体Symfony 原则2本机查询从联接实体中选择,symfony,doctrine-orm,symfony-2.5,Symfony,Doctrine Orm,Symfony 2.5,注意:这是特定的本机查询 我有两个相关实体“CrmBusinessPartner”和“RefCountry”以及“crmbusinesspartnersepository”存储库 CrmBusinessPartner实体 /** * CrmBusinessPartner * * @ORM\Table(name="crm_business_partner") * @ORM\Entity(repositoryClass="CrmBusinessPartnerRepository") * @
/**
* CrmBusinessPartner
*
* @ORM\Table(name="crm_business_partner")
* @ORM\Entity(repositoryClass="CrmBusinessPartnerRepository")
* @Gedmo\SoftDeleteable(fieldName="deletedAt", timeAware=false)
* @ExclusionPolicy("none")
*/
class CrmBusinessPartner
{
/**
*
* @var integer
*
* @ORM\ManyToOne(targetEntity="RefCountry", inversedBy="businessPartners")
* @ORM\JoinColumn(name="ref_country_id", referencedColumnName="id")
*/
private $billingCountry;
}
/**
* RefCountry
*
* @ORM\Table(name="ref_country")
* @ORM\Entity
*/
class RefCountry
{
/**
* @ORM\OneToMany(targetEntity="CrmBusinessPartner", mappedBy="billingCountry")
*/
private $businessPartners;
public function __construct()
{
$this->businessPartners= new ArrayCollection();
}
}
参考国家/地区实体
/**
* CrmBusinessPartner
*
* @ORM\Table(name="crm_business_partner")
* @ORM\Entity(repositoryClass="CrmBusinessPartnerRepository")
* @Gedmo\SoftDeleteable(fieldName="deletedAt", timeAware=false)
* @ExclusionPolicy("none")
*/
class CrmBusinessPartner
{
/**
*
* @var integer
*
* @ORM\ManyToOne(targetEntity="RefCountry", inversedBy="businessPartners")
* @ORM\JoinColumn(name="ref_country_id", referencedColumnName="id")
*/
private $billingCountry;
}
/**
* RefCountry
*
* @ORM\Table(name="ref_country")
* @ORM\Entity
*/
class RefCountry
{
/**
* @ORM\OneToMany(targetEntity="CrmBusinessPartner", mappedBy="billingCountry")
*/
private $businessPartners;
public function __construct()
{
$this->businessPartners= new ArrayCollection();
}
}
在“CrmBusinessPartnerRepository”存储库中有以下工作代码:
$rsm = new \Doctrine\ORM\Query\ResultSetMapping();
$rsm->addEntityResult('Entity\CrmBusinessPartner', 'bp');
$rsm->addFieldResult('bp','id','id');
$rsm->addFieldResult('bp','vat','vat');
$rsm->addFieldResult('bp','business_partner_name','name');
$rsm->addJoinedEntityResult('Entity\RefCountry', 'rc', 'bp', 'billingCountry');
$rsm->addFieldResult('rc','ref_country_name','name');
$em = $this->getEntityManager()
->createNativeQuery('
SELECT
bp.id,
bp.vat,
bp.name AS business_partner_name,
rc.name AS ref_country_name
FROM crm_business_partner bp
LEFT JOIN ref_country rc ON bp.ref_country_id=rc.id
',
$rsm
);
return $em->getResult();
数据库处于同步状态(根据条令:模式:更新):
这是一个结果转储:
array ()
0 =>
object(Entity\CrmBusinessPartner)
private 'id' => int 42
private 'vat' => string '12345678998' (length=11)
private 'name' => string 'Name 1' (length=22)
private 'billingCountry' => null
问题: 我不明白为什么billingCountries对所有实体都是空的?
编辑: 我已经有了QueryBuilder的工作解决方案:
$qb = $this->getEntityManager()->createQueryBuilder('bp');
$qb->select(array('bp'));
$qb->from('AppBundle:CrmBusinessPartner', 'bp');
$qb->leftJoin('bp.billingCountry', 'rc');
return $qb->getQuery()->getResult();
编辑2:
“CrmBusinessPartnerRepository”存储库使用ResultsMappingBuilder而不是ResultsMapping,这是一个工作代码:
$rsm = new ResultSetMappingBuilder($this->getEntityManager());
$rsm->addRootEntityFromClassMetadata(
'Entity\CrmBusinessPartner',
'bp'
);
$rsm->addJoinedEntityFromClassMetadata(
'Entity\RefCountry',
'rc',
'bp',
'billingCountry',
array(
'id' => 'billing_country_id',
'name'=>'rc_name'
)
);
$em = $this->getEntityManager()
->createNativeQuery('
SELECT
bp.id,
bp.vat,
bp.name AS business_partner_name,
rc.name AS ref_country_name
FROM crm_business_partner bp
LEFT JOIN ref_country rc ON bp.ref_country_id=rc.id
',
$rsm
);
return $em->getResult();
结果相同所有实体的billingCountry始终为空:
array ()
0 =>
object(Entity\CrmBusinessPartner)
private 'id' => int 42
private 'vat' => string '12345678998' (length=11)
private 'name' => string 'Name 1' (length=22)
private 'billingCountry' => null
我想知道为什么/如何/如何使用本机查询工作/做(它)?好吧,好吧,好吧…看起来你必须添加
rc.id作为ref\u country\u id,
在查询中,$rsm->addFieldResult('rc','ref\u country\u id','id')代码>如下所示:
$rsm = new \Doctrine\ORM\Query\ResultSetMapping();
$rsm->addEntityResult('Entity\CrmBusinessPartner', 'bp');
$rsm->addFieldResult('bp','id','id');
$rsm->addFieldResult('bp','vat','vat');
$rsm->addFieldResult('bp','business_partner_name','name');
$rsm->addJoinedEntityResult('Entity\RefCountry', 'rc', 'bp', 'billingCountry');
$rsm->addFieldResult('rc','ref_country_id','id');
$rsm->addFieldResult('rc','ref_country_name','name');
$em = $this->getEntityManager()
->createNativeQuery('
SELECT
bp.id,
bp.vat,
bp.name AS business_partner_name,
rc.id AS ref_country_id,
rc.name AS ref_country_name
FROM crm_business_partner bp
LEFT JOIN ref_country rc ON bp.ref_country_id=rc.id
',
$rsm
);
return $em->getResult();
它像预期的那样工作
我希望有人在之前告诉我(条令文档…看着你):D为什么你要在这个案例中使用NativeQuery(而不是DQL)?我很无聊,只是不想限制自己:实际上,你是在限制自己,因为使用NativeQuery时,你使用的是特定于供应商的SQL,而DQL则与供应商无关;)但是为了测试和了解图书馆,我完全支持你!您确实需要获取CrmBusinessPartner
和RefCountry
之间关联中使用的标识符,否则条令无法确定哪个属于哪个。