我試圖從我的PHP實體創建我的數據庫與Doctrine 2。CLI Doctrine 2-索引已經定義
下面是來自一流的團隊我的代碼:
<?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'
學說是由作曲家加載和使用與Windows CMD(如果這能幫助)。
我已經看到一個問題已經報告v.2.5.0,所以我加載2.4.7但同樣的錯誤,所以我嘗試開發主,但仍然是相同的。
我也嘗試刪除複合標識並將其替換爲簡單的生成@Id,甚至沒有(原則是然後說實體「團隊」沒有指定標識符/主鍵)。
此代碼與v.2.4.2一起使用,但重點是更新用於此項目的工具。
有人知道我該怎麼做嗎?
你能提供整體嗎?這是特別的註釋。 –
當然可以!這是整個文件。請注意,我可以在沒有Team類的情況下創建數據庫,這是唯一不起作用的文件。 – Lanfeust