symfonyで例えば以下のエンティティがあったとき、タグに属する記事を取得する
class Tag
{
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string", length=32)
*/
private $name;
}
class Entry
{
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="string", length=32)
*/
private $title;
/**
* @ORM\ManyToMany(targetEntity=Tag::class)
*/
private $Tag;
}
ManyToMany
でリレーションされているのでDQLでは
$qb
->andWhere(':tag MEMBER OF a.Tag')
->setParameter('tag', $tag)
;
の様になる。
複数のタグで検索するには?
調べてみたけど出てこなかったので試行錯誤した結果以下でいけた
$qb
->andWhere(':tags MEMBER OF a.Tag')
->setParameter('tags', [$tag1, $tag2])
;