Symfony 2 knplabs表单转换 - 更改referenceColumName的最佳方法

时间:2015-04-09 13:22:45

标签: doctrine-orm symfony-2.6 a2lix-translation

A2lix需要'id'作为referenceColumName。但我的实体具有不同的columName(例如ProductID而不是id)。因此,当我尝试通过doctrine更新我的数据库时出现错误:schema:update --force。

我的实体示例

class Period
{

    use ORMBehaviors\Translatable\Translatable,
        ORMBehaviors\Timestampable\Timestampable,
        ORMBehaviors\SoftDeletable\SoftDeletable
    ;

    /**
     * @var integer
     *
     * @ORM\Column(name="PeriodID", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

...

KnippingDoctrineBehaviors包的TranslatableSubscriber类的一部分

...

   private function mapTranslatable(ClassMetadata $classMetadata)
    {
        if (!$classMetadata->hasAssociation('translations')) {
            $classMetadata->mapOneToMany([
                'fieldName'     => 'translations',
                'mappedBy'      => 'translatable',
                'indexBy'       => 'locale',
                'cascade'       => ['persist', 'merge', 'remove'],
                'fetch'         => $this->translatableFetchMode,
                'targetEntity'  => $classMetadata->getReflectionClass()->getMethod('getTranslationEntityClass')->invoke(null),
                'orphanRemoval' => true
            ]);
        }
    }

    private function mapTranslation(ClassMetadata $classMetadata)
    {
        if (!$classMetadata->hasAssociation('translatable')) {

            $classMetadata->mapManyToOne([
                'fieldName'    => 'translatable',
                'inversedBy'   => 'translations',
                'fetch'         => $this->translationFetchMode,
                'joinColumns'  => [[
                    'name'                 => 'translatable_id',
                    'referencedColumnName' => 'id',
                    'onDelete'             => 'CASCADE'
                ]],
                'targetEntity' => $classMetadata->getReflectionClass()->getMethod('getTranslatableEntityClass')->invoke(null),
            ]);
        }

        $name = $classMetadata->getTableName().'_unique_translation';
        if (!$this->hasUniqueTranslationConstraint($classMetadata, $name)) {
            $classMetadata->table['uniqueConstraints'][$name] = [
                'columns' => ['translatable_id', 'locale' ]
            ];
        }

        if (!$classMetadata->hasField('locale')) {
            $classMetadata->mapField(array(
                'fieldName' => 'locale',
                'type'      => 'string'
            ));
        }

    }

...

任何想法或帮助都会受到赞赏。

非常感谢; - )

1 个答案:

答案 0 :(得分:0)

您可以使用: association override

我尝试覆盖属性,但它们是由订阅者创建的,并且出现异常。您还可以在实体类上重新声明注释 manyToOne。 它对我有用。