Доктрина CLI 2 — индекс уже определен

Я пытаюсь создать свою базу данных с Doctrine 2 из моей сущности PHP.

Вот мой код из класса Team:

<?php
// Team.php
/**
* @Entity @Table(name="team")
**/
class Team
{
/**
* @Id
* @OneToOne(targetEntity="User")
* @JoinColumn(name="userID", referencedColumnName="id")
*/
protected $user;

/**
* @Column(type="string",length=30)
* @var string
**/
protected $function;

/**
* @Column(type="text")
* @var string
**/
protected $description;

/**
* @OneToOne(targetEntity="File")
* @JoinColumn(name="fileID", referencedColumnName="id")
*/
protected $img;

/**
* @OneToOne(targetEntity="File")
* @JoinColumn(name="fileID", referencedColumnName="id")
*/
protected $cv;

/**
* @Id
* @OneToOne(targetEntity="Language")
* @JoinColumn(name="languageID", referencedColumnName="id")
*/
protected $lang;

public function getUser()
{
return $this->user;
}

public function setUser(User $user)
{
$this->user = $user;
}

public function getFunction()
{
return $this->function;
}

public function setFunction($function)
{
$this->function = $function;
}

public function getDescription()
{
return $this->description;
}

public function setDescription($description)
{
$this->description = $description;
}

public function getImg()
{
return $this->img;
}

public function setImg($img)
{
$this->img = $img;
}

public function getCv()
{
return $this->cv;
}

public function setCv($cv)
{
$this->cv = $cv;
}

public function getLang()
{
return $this->lang;
}

public function setLang(Language $language)
{
$this->lang = $language;
}
}

И ошибка:

[Doctrine\DBAL\Schema\SchemaException]
An index with name 'uniq_c4e0a61f93cb796c' was already defined on table 'team'

Doctrine загружается из composer и используется с Windows CMD (если это может помочь).

Я видел, что сообщается о проблеме для v.2.5.0, поэтому я загрузил 2.4.7, но с той же ошибкой, поэтому я попробовал dev-master, но все тот же.

Я также попытался удалить составной Id и заменил его на простой сгенерированный @Id, или даже вообще без него (Doctrine тогда говорил, что для Entity «Team» не указан идентификатор / первичный ключ).

Этот код работал с v.2.4.2, но суть в том, чтобы обновить инструменты, используемые для этого проекта.

Кто-нибудь знает, как я мог это сделать?

4

Решение

Ну хорошо, я нашел проблему:

/**
* @OneToOne(targetEntity="File")
* @JoinColumn(name="fileID", referencedColumnName="id")
*/
protected $img;

/**
* @OneToOne(targetEntity="File")
* @JoinColumn(name="fileID", referencedColumnName="id")
*/
protected $cv;

Точнее @JoinColumn(name="fileID", referencedColumnName="id"), имя столбца fileID одинаково для обоих.

Спасибо, в любом случае !

6

Другие решения

Ваша проблема заключается здесь:

/**
* @Id
* @OneToOne(targetEntity="Language")
* @JoinColumn(name="languageID", referencedColumnName="id")
*/
protected $lang;

Вы должны удалить @Id от твоего $lang имущество. Ассоциации не должны быть помечены как идентификаторы сущностей.

@Id аннотация используется для обозначения первичного ключа (http://doctrine-orm.readthedocs.org/en/latest/reference/annotations-reference.html#annref-id). Ваша связь не является первичным ключом, при миграции доктрина схемы попытается добавить индекс и сопоставить внешний ключ (в зависимости от конфигурации).

Поскольку вы пометили ассоциацию как идентификатор, это противоречит вашему $id ключ.

0

По вопросам рекламы [email protected]