php - Symfony2 OneToMany双向引用非id列

标签 php mysql symfony doctrine

我依赖外部 API 来填充我的表,通过这种关系,我可以用更少的查询来处理应用程序上的一些所需功能。

在使用命令后创建表和 FK,而不是错误和警告,但我不知道是否可以绕过此错误,否则将来会产生问题。

显然,我可以只引用 ID,问题就会消失,但如果可能的话,现在就需要这样做。

我有两个表:

RARITIES

id
name
...

ITEMS

id
item_rarity
...

实体看起来像:

class Rarity
{
    ...

    /**
     * @ORM\OneToMany(targetEntity="Item", mappedBy="rarity")
     */
    private $items;

    public function __construct() {
        $this->items = new ArrayCollection();
    }

    ...
}

class Item
{
    ...

    /**
     * @ORM\ManyToOne(targetEntity="Rarity", inversedBy="items")
     * @ORM\JoinColumn(name="item_rarity", referencedColumnName="name")
     **/
     private $rarity;

    ...
}

当我创建或更新架构时,它会输出一些错误和警告:

[Doctrine\ORM\Tools\ToolsException]                                                                                                                                              
Schema-Tool failed with Error 'An exception occurred while executing 'ALTER TABLE items    ADD CONSTRAINT FK_E11EE94D3139CB89 FOREIGN KEY (item_rarity) REFERENCES rarities (name)':                                                                                                                                                                               
SQLSTATE[HY000]: General error: 1005 Can't create table 'd2a.#sql-4fa_7c' (errno: 150)' while executing DDL: ALTER TABLE items ADD CONSTRAINT FK_E11EE94D3139CB89 FOREIGN KEY (item_rarity) REFERENCES rarities (name)                                                                                                                                                                                                                                                                                 


[Doctrine\DBAL\DBALException]                                                                                                                       
An exception occurred while executing 'ALTER TABLE items ADD CONSTRAINT  K_E11EE94D3139CB89 FOREIGN KEY (item_rarity) REFERENCES rarities (name)':  
SQLSTATE[HY000]: General error: 1005 Can't create table 'd2a.#sql-4fa_7c' (errno: 150)                                                              

[PDOException]                                                                          
SQLSTATE[HY000]: General error: 1005 Can't create table 'd2a.#sql-4fa_7c' (errno: 150

感谢您的建议!

最佳答案

我怀疑这与试图通过“名称”将两者联系起来有关,Doctrine 不认为这是一个唯一的标识符。就 Doctrine 而言,可能有两个同名的稀有元素。 'id' 起作用的原因是因为它在注释中使用 @Id 声明为主键,因此假定是唯一的:

/**
 * @ORM\Column(type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
protected $id;

如果不进行深入研究,我会假设这种关系需要 Items 引用回主键。

关于php - Symfony2 OneToMany双向引用非id列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24711373/

相关文章:

java.lang.NullPointerException-登录 servlet

PHP/MySQL 链接每个单词

xml - Symfony2 - 为什么使用 XML 进行设置/配置?

php - 从电子邮件地址中查找大学名称

php - 如何在Android中以较少的数据使用量从服务器获取消息?

php - Eloquent 将 POINT 数据返回为 UTF8

php - Symfony2 递归查询生成器

php - Laravel Passport 路由重定向到登录页面

mysql - 如何将Excel文件导入MySQL Workbench?

symfony - 用于Symfony 3.4中一对多关系的自定义 Hydrator