我似乎无法弄清楚这一点,尽管它应该是相当简单的事情。
我有图像实体和文章实体。许多文章可以使用相同的图像,但每篇文章只能有一个图像,因此它们被映射为 OneToMany<->ManyToOne。
现在,我只需要选择没有任何相关文章的图像。我该怎么做呢?
我试过:
$repository->createQueryBuilder('i')
->select('i')
->where('count(i.articles) = NULL');
但它不起作用。我怎样才能做到这一点?
更新
我在 Type 类中使用它,并试图创建仅包含未使用实体的实体字段,如果相关,这里是完整的功能代码:
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('images', 'entity', array(
'class' => 'BloggerBlogBundle:Image',
'query_builder' =>
function(EntityRepository $er)
{
return $er->createQueryBuilder('i')->.........here goes query creation
},
)
)
;
}
如果需要,这里也是关联:
图像类:
/**
* @ORM\OneToMany(targetEntity="Blog", mappedBy="image")
*/
protected $articles;
博客类:
/**
* @ORM\ManyToOne(targetEntity="Image", inversedBy="articles")
*/
protected $image;