この質問のように、2つのテーブルから3番目までの余分な行との間に関係があります
/** @Entity
*/
class Illness {
/** @Id @GeneratedValue @Column(type="integer") */
private $illness_id;
/** @Column(type="string") */
private $name;
/** @OneToMany(targetEntity="Illness_Symptom_Association", mappedBy="Illness") */
private $symptAssoc;
public function __construct()
{
$this->symptAssoc = new \Doctrine\Common\Collections\ArrayCollection();
}
public function setName($val)
{
$this->name = $val;
}
public function getName()
{
return $this->name;
}
public function getSymptAssoc()
{
return $this->symptAssoc;
}
}
3番目のパラメーターでテーブルを結合します(優先度のようなもの)
/**
* @Entity
*/
class Illness_Symptom_Association {
protected $illness_id;
/**
* @Id()
* @ManyToOne(targetEntity="Illness", inversedBy="symptAssoc")
* @JoinColumn(name="illness_id", referencedColumnName="illness_id", nullable=false)
*/
protected $illness;
/**
* @Id()
* @ManyToOne(targetEntity="Symptom", inversedBy="symptAssoc")
* @JoinColumn(name="symptom_id", referencedColumnName="symptom_id")
* */
protected $symptom;
/** @Column(type="integer") */
protected $s;
public function setIllness(Illness $illness)
{
$this->illness = $illness;
}
/**
*
* @return Illness
*/
public function getIllness()
{
return $this->illness;
}
public function setSymptom(Symptom $sympt)
{
return $this->symptom = $sympt;
}
public function getSymptom()
{
return $this->symptom;
}
public function setS($s)
{
$this->s = $s;
}
public function getS()
{
return $this->s;
}
}
症状のある最後のエンティティ:
/**
* @Entity
*/
class Symptom {
/** @Id @GeneratedValue @Column(type="integer") */
protected $symptom_id;
/** @Column(type="string", unique=true) */
protected $name;
/** @OneToMany(targetEntity="Illness_Symptom_Association", mappedBy="symptom") */
protected $symptAssoc;
public function setName($name)
{
$this->name = $name;
}
public function getName($name)
{
return $this->name;
}
}
しかし
$illness = $em->getRepository('Entity\Illness')->find($id);
$illness->getSymptAssoc();
PersistentCollectionオブジェクトを返します。
結合テーブルからsパラメータを使用して症状のリストを取得するにはどうすればよいですか?