Php CLI原则2-已定义索引

Php CLI原则2-已定义索引,php,doctrine-orm,doctrine,entity,identifier,Php,Doctrine Orm,Doctrine,Entity,Identifier,我正试图从我的PHP实体中使用Doctrine 2创建数据库 以下是我来自班级团队的代码: <?php // Team.php /** * @Entity @Table(name="team") **/ class Team { /** * @Id * @OneToOne(targetEntity="User") * @JoinColumn(name="userID", referencedColumnName="id") */

我正试图从我的PHP实体中使用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;
    }
}
条令从composer加载,并与Windows CMD一起使用(如果有帮助的话)

我已经看到v.2.5.0报告了一个问题,所以我加载了2.4.7,但出现了相同的错误,所以我尝试了dev master,但仍然是相同的

我还尝试删除复合Id,并将其替换为一个简单生成的@Id,甚至没有(当时的原则是没有为实体“Team”指定标识符/主键)

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

有人知道我怎么做吗?

你的问题在于:

/**
 * @Id
 * @OneToOne(targetEntity="Language")
 * @JoinColumn(name="languageID", referencedColumnName="id")
 */
protected $lang;
您必须从
$lang
属性中删除
@Id
。关联不应标记为实体标识符

@Id
注释用于标记主键()。您的关联不是主键,迁移模式时,将尝试添加索引并映射外键(取决于配置)


由于您将关联标记为标识符,这与
$id
键冲突。

好吧,我发现了问题:

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


无论如何谢谢你

你能提供整个实体吗?特别是注释。当然!这是全部文件。请注意,我可以在没有类团队的情况下创建数据库,它是唯一不起作用的文件。我删除了此
@Id
,并在
$user
上删除了另一个,因为它也是FK。很抱歉,按enter键太快。。不,不是,我还删除了另一个Id,因为它也是一个FK,并创建了一个生成的Id,但仍然不正常。这很奇怪,因为我有另一个实体在使用复合Id,其中一个是
$lang
上的
@Id
。您是在现有数据库上运行
原则:模式:更新
,还是在空数据库上运行
原则:模式:创建
?在空数据库上创建?这是原则中的一个错误,还是我们不能使用一列超过一次?那是我的错误。您不能有两个完全相同的列名称,这是非常合乎逻辑的。
/**
 * @OneToOne(targetEntity="File")
 * @JoinColumn(name="fileID", referencedColumnName="id")
 */
protected $img;

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