Php Symfony2 OneToMany双向引用非id列
我依靠外部api来填充我的表,通过这种关系,我可以用较少的查询处理应用程序上的一些必需函数 表和FK不是在使用该命令后创建的错误和警告,而是在使用该命令后创建的,但我不知道是否可以绕过此错误,否则将来会产生问题 显然,我可以只引用id,问题将消失,但如果这是可能的话,现在需要这样做 我有两张桌子:Php Symfony2 OneToMany双向引用非id列,php,mysql,symfony,doctrine,Php,Mysql,Symfony,Doctrine,我依靠外部api来填充我的表,通过这种关系,我可以用较少的查询处理应用程序上的一些必需函数 表和FK不是在使用该命令后创建的错误和警告,而是在使用该命令后创建的,但我不知道是否可以绕过此错误,否则将来会产生问题 显然,我可以只引用id,问题将消失,但如果这是可能的话,现在需要这样做 我有两张桌子: RARITIES id name ... ITEMS id item_rarity ... 实体看起来像: class Rarity { ... /** * @OR
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
谢谢你的建议 我怀疑这与试图通过“名称”将两者联系起来有关,该学说认为这不是唯一的标识符。就教义而言,可能有两种罕见的事物同名。“id”起作用的原因是,它在注释中使用
@id
声明为主键,因此被假定为唯一的:
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
在不深入研究的情况下,我假设这种关系需要
项引用回主键。首先,多亏了Alex,他让我知道了发生了什么
正如他所说的“就教义而言,可能有两种稀有物品具有相同的名称”,因此,让我们将raries.name列设为唯一:
/**
* Rarity
*
* @ORM\Table(name="rarities",
* uniqueConstraints={@ORM\UniqueConstraint(name="unique_name", columns={"name"})})
* @ORM\Entity
*/
class Rarity
{
它可以工作,没有错误,没有警告,列items.item_rarity引用rarities.name和rarities.name不是表中的主键
我希望它能帮助别人,这花了我很多时间 Ty man,但正如我所说的,我知道添加这一点可以解决问题,我想知道为什么表和FK被正确创建,但是警告和错误出现了,这就是我想知道的原因。太好了。祝你的项目好运。