Symfony2,Sonata MediaBundle:向表中添加新字段

时间:2015-02-26 15:59:43

标签: php symfony doctrine-orm sonata sonata-media-bundle

我试图在Sonata MediaBundle中为GalleryHasMedia添加4个新字段。

我正确覆盖了GalleryHasMediaAdmin:

GalleryHasMedia

要覆盖它,我在services.yml中添加了这一行:

parameters:
    sonata.media.admin.gallery_has_media.class: Application\Sonata\MediaBundle\Admin\GalleryHasMediaAdmin

我必须手动创建方法(getName和else)因为php app / console doctrine:generate:entities ApplicationSonataMediaBundle:GalleryHasMedia 显然不关心我的自定义实体Application \ Sonata \ MediaBundle \ Entity \ GalleryHasMedia中设置的新字段。

同样--dump-sql返回"无需更新"。但是在Sonata管理员中可以正确识别方法(getName和else),那么为什么不使用新字段?

这是我的自定义实体:

<?php
namespace Application\Sonata\MediaBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Sonata\MediaBundle\Entity\BaseGalleryHasMedia as BaseGalleryHasMedia;

/**
 * @ORM\Entity
 * @ORM\Table(name="media__gallery_media")
 */
class GalleryHasMedia extends BaseGalleryHasMedia
{

    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\Column(type="string", length=64, nullable=false, name="name")
     **/
    private $name;

    /**
     * @ORM\Column(type="string", length=64, nullable=false, name="activity")
     **/
    private $activity;

    /**
     * @ORM\Column(type="text", nullable=false, name="description")
     */
    private $description;

    /**
     * @ORM\Column(type="string", length=255, nullable=false, name="code")
     **/
    private $link;

    /**
     * Get id
     *
     * @return integer $id
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set name
     *
     * @param string $name
     * @return GalleryHasMedia
     */
    public function setName($name)
    {
         $this->name = $name;

        return $this;
    }

    /**
     * Get name
     *
     * @return string
     */
    public function getName()
    {
        return $this->name;
    }

    /**
     * Set activity
     *
     * @param string $activity
     * @return GalleryHasMedia
     */
    public function setActivity($activity)
    {
        $this->activity = $activity;

        return $this;
    }

    /**
     * Get activity
     *
     * @return string
     */
    public function getActivity()
    {
        return $this->activity;
    }

    /**
     * Set description
     *
     * @param string $description
     * @return GalleryHasMedia
     */
    public function setDescription($description)
    {
        $this->description = $description;

        return $this;
    }

    /**
     * Get description
     *
     * @return string
     */
    public function getDescription()
    {
        return $this->description;
    }

    /**
     * Set link
     *
     * @param string $link
     * @return GalleryHasMedia
     */
    public function setLink($link)
    {
        $this->link = $link;

        return $this;
    }

    /**
     * Get link
     *
     * @return string
     */
    public function getLink()
    {
         return $this->link;
    }

}

我正确地按照Documentation中的说法设置了

sonata_media:
    # if you don't use default namespace configuration
    class:
        media: Application\Sonata\MediaBundle\Entity\Media
        gallery: Application\Sonata\MediaBundle\Entity\Gallery
        gallery_has_media: Application\Sonata\MediaBundle\Entity\GalleryHasMedia

我使用自动映射,因此我的自定义实体已正确映射:

  

[确定] Application \ Sonata \ MediaBundle \ Entity \ GalleryHasMedia

这里是实际的表格(奏鸣曲的默认表格):

Sonata's default table

那么为什么我不能将任何新字段添加到gallery_has_media表中的任何想法?

更新:

我猜这是因为我正在使用注释。如何继续使用注释并使其与我的数据库同步?

这个家伙遇到了类似的问题Issue

1 个答案:

答案 0 :(得分:0)

好的,我发现答案正确解释了here

删除Application / Sonata / MediaBundle / Resources / config / doctrine允许我在自定义实体中使用注释。