如何使用 Doctrine 2 中的类表继承指定用于外键关系的列?例如,采取以下两个类:
/**
* @Entity
* @InhertanceType("JOINED")
* @DiscriminatorColumn(name="type", type="string")
* @DiscriminatorMap("person" = "Person", "employee" = "Employee")
*/
class Person
{
/** @Id */
public $id;
/** @Column(type="string") */
public $ssn;
}
/** @Entity */
class Employee
{
/** @Column(type="decimal") */
public $salary;
}
有了这个,Doctrine 期望一个表结构有点像这样:
CREATE TABLE `person` (
`id` INT(11) NOT NULL auto_increment,
`ssn` VARCHAR(255) default NULL,
PRIMARY_KEY(`id`)
)
CREATE TABLE `employee` (
`person_id` INT(11) NOT NULL,
`salary` DECIMAL(10,2) default NULL,
PRIMARY_KEY(`person_id`)
)
ALTER TABLE `employee`
ADD CONSTRAINT `person_fk` FOREIGN KEY (`person_id`)
REFERENCES `person` (`id`) ON DELETE CASCADE
有一个employee.person_id
指向的外键person.id
。但是我怎样才能告诉 Doctrine 使用哪些列呢?我假设person.id
引用来自类@Id
上的注释Person
,但如果我想创建 FK 来person.ssn
代替(这是可以想象的,因为 SSN 自然是唯一的)。
如果我有一个旧数据库employee.person_id
被调用employee.p_id
怎么办?