簡體   English   中英

表與實體聯接(Symfony)

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM