Doctrine orm Symfony 2 knplabs表单翻译-更改参考列名称的最佳方式

Doctrine orm Symfony 2 knplabs表单翻译-更改参考列名称的最佳方式,doctrine-orm,symfony-2.6,a2lix-translation,Doctrine Orm,Symfony 2.6,A2lix Translation,A2lix需要“id”作为referenceColumName。但是我有不同列名的实体(例如ProductID而不是id)。所以当我试图通过条令:schema:update--force更新我的数据库时,我得到了一个错误 我的实体示例 class Period { use ORMBehaviors\Translatable\Translatable, ORMBehaviors\Timestampable\Timestampable, ORMBehavio

A2lix需要“id”作为referenceColumName。但是我有不同列名的实体(例如ProductID而不是id)。所以当我试图通过条令: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;

...
KnpDoctrineBehaviors包可翻译订户类的一部分

...

   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'
            ));
        }

    }

...
任何想法或帮助都将不胜感激

非常感谢;-)

您可以使用:

我试图重写属性,但它们是由订阅者创建的,因此出现异常。还可以在实体类上重新声明注释
manytone

这对我很有用。

嘿,本杰明,我也有同样的要求。你有没有找到一个设置自定义“referencedColumnName”的好方法?