gpt4 book ai didi

php - CLI Doctrine 2 - 索引已经定义

转载 作者:可可西里 更新时间:2023-10-31 22:10:36 25 4
gpt4 key购买 nike

我正在尝试从我的 PHP 实体中使用 Doctrine 2 创建我的数据库。

这是我来自类(class)团队的代码:

<?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 当时说没有为实体“团队”指定标识符/主键)。

此代码适用于 v.2.4.2,但重点是更新用于此项目的工具。

有人知道我该怎么做吗?

最佳答案

好吧好吧,我发现了问题:

/**
* @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 相同。

还是谢谢你!

关于php - CLI Doctrine 2 - 索引已经定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31522922/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com