Payum Symfony Doctrine无法创建表格

时间:2016-05-24 01:02:03

标签: php symfony doctrine-orm stripe-payments payum

我正在尝试将配置文件(称为Square)的引用添加到我的Payment模型(Payum \ Core \ Model \ ArrayObject的扩展名),但是我无法在表上添加外键。我想这样做,以便在处理付款时,我可以更新一个字段,说明该广场现已支付。这是我的设置:

Square.php

/**
 * @var integer
 *
 * @ORM\Column(name="msid", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="IDENTITY")
 */
private $msid;

Payment.php

/**
 * @ORM\OneToOne(targetEntity="Square")
 * @ORM\JoinColumn(name="msid", referencedColumnName="msid")
 */
private $square;

错误代码:

[Doctrine\DBAL\Exception\DriverException]
 An exception occurred while executing 'ALTER TABLE payment ADD CONSTRAINT FK_6D28840D405F5364 FOREIGN KEY (msid) REFERENCES square (msid)':  
  SQLSTATE[HY000]: General error: 1005 Can't create table 'memorysq_version2.#sql-1658_1487b' (errno: 150)

其他几个实体使用msid字段加入,它只是不使用我的Payum Payment模型。

[Doctrine\DBAL\Driver\PDOException]                                                                       
 SQLSTATE[HY000]: General error: 1005 Can't create table 'memorysq_version2.#sql-1658_1487b' (errno: 150)

[PDOException]                                                                                            
 SQLSTATE[HY000]: General error: 1005 Can't create table 'memorysq_version2.#sql-1658_1487b' (errno: 150)

输出--dump-sql

ALTER TABLE comment ADD CONSTRAINT FK_9474526C405F5364 FOREIGN KEY (msid) REFERENCES square (msid);
ALTER TABLE asset ADD CONSTRAINT FK_2AF5A5C405F5364 FOREIGN KEY (msid) REFERENCES square (msid);
ALTER TABLE payment ADD CONSTRAINT FK_6D28840D405F5364 FOREIGN KEY (msid) REFERENCES square (msid);
ALTER TABLE square ADD CONSTRAINT FK_CDE368A9F132696E FOREIGN KEY (userid) REFERENCES user (userid);
ALTER TABLE square ADD CONSTRAINT FK_CDE368A96AFF851C FOREIGN KEY (squaretype) REFERENCES product (id);
ALTER TABLE square ADD CONSTRAINT FK_CDE368A9DC01AA6E FOREIGN KEY (dualpicture) REFERENCES asset (assetid);
ALTER TABLE square ADD CONSTRAINT FK_CDE368A97F98CD1C FOREIGN KEY (clientid) REFERENCES client (clientid);
ALTER TABLE square ADD CONSTRAINT FK_CDE368A916DB4F89 FOREIGN KEY (picture) REFERENCES asset (assetid);

其他几个实体使用msid字段加入,它只是不使用我的Payum Payment模式。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:1)

错误消息实际上表明MySQL无法创建外键。由于您正在执行ALTER TABLE,因此表格应该已存在。由于这些表可能已经存在,可能是payment表中已有一些数据,这些数据不在square表中。

值得研究的其他内容是两列是否具有完全相同的类型(包括有符号/无符号)并且具有匹配的排序规则。在表级别,您可以查看引擎是否相同,如果charset是相同的,并且两个表都不是临时表。