[英]Table join with entity (Symfony)
我是Symfony的新手,無法設置實體。 我希望能夠從我的Acasset實體訪問標簽名稱。
以下是相關實體:
class Actag
{
/**
* @var string
*
* @ORM\Column(name="tag_name", type="string", length=200, nullable=true)
*/
private $tagName;
/**
* @var integer
*
* @ORM\Column(name="tag_id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $tagId;
/**
* Acassettag
*
* @ORM\Table(name="acAssetTag", indexes={@ORM\Index(name="IDX_7C4A2A745DA1941", columns={"asset_id"}), @ORM\Index(name="IDX_7C4A2A74BAD26311", columns={"tag_id"})})
* @ORM\Entity
*/
class Acassettag
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var \AdminBundle\Entity\Acasset
*
* @ORM\ManyToOne(targetEntity="AdminBundle\Entity\Acasset", inversedBy="asset", cascade="PERSIST")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="asset_id", referencedColumnName="asset_id")
* })
*/
private $asset;
/**
* @var \AdminBundle\Entity\Actag
*
* @ORM\ManyToOne(targetEntity="AdminBundle\Entity\Actag")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="tag_id", referencedColumnName="tag_id")
* })
*/
private $tag;
/**
* Acasset
*
* @ORM\Table(name="acAsset", indexes={@ORM\Index(name="IDX_3B81679E68BA92E1", columns={"asset_type"}), @ORM\Index(name="IDX_3B81679E12469DE2", columns={"category_id"})})
* @ORM\Entity(repositoryClass="AdminBundle\Repository\AcAssetRepository")
*/
class Acasset
{
/**
* @var string
*
* @ORM\Column(name="asset_name", type="string", length=100, nullable=false)
*/
private $assetName;
/**
* @var integer
*
* @ORM\Column(name="asset_id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $assetId;
/**
* @var \AdminBundle\Entity\Acassettype
*
* @ORM\OneToOne(targetEntity="AdminBundle\Entity\Acassettype", mappedBy="asset", fetch="EAGER", cascade={"persist"})
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="asset_type_id", referencedColumnName="asset_type_id")
* })
*/
private $assetType;
/**
* @var \AdminBundle\Entity\Actag
*
* @ORM\ManyToOne(targetEntity="AdminBundle\Entity\Actag")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="tag_id", referencedColumnName="tag_id")
* })
*/
private $assetTags;
/**
* Set tag
*
* @param \AdminBundle\Entity\Actag $tag
*
* @return Acassettag
*/
public function setAssetTags(\AdminBundle\Entity\Actag $tag = null)
{
$this->tag = $tag;
return $this;
}
/**
* Get tag
*
* @return \AdminBundle\Entity\Actag
*/
public function getAssetTags()
{
return $this->tag;
}
因此,在我的Acasset實體中,我創建了$ assetTags,但出現錯誤:無效的列名'tag_id'。
但是Acasettag實體中的$ tag可以工作,其設置方法相同。 我缺少什么,仍然在Symfony的這一部分中苦苦掙扎。
我沒有在這篇文章中包括所有的獲取器和設置器,只是我為此而創建的。
為什么您的Actag
-Entity hat還是tagId
字段? 您不需要在擁有側上定義Id列。 您必須定義一個OneToMany。
許多Acassettag
由一個擁有Actag
(因為在多對一清晰度的Acassettag
所以每Acassettag
需要現場actag_id
與所屬的Id Actag
將由您來自動生成ManyToOne
-Definition
當您創建新的Acassettag
實體並將其與現有Actag
“連接”時,您需要Acassettag
public setActag(Actag $actag)
{
$this->tag = $actag;
return $this;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.