问题描述
我正在尝试在两个类之间建立ManyToMany关联,并在字段上附加约束...
我有两个班级A和B:
A可以有很多B,而B可以有很多A。 这样可以很好地工作并生成一个连接表A_B:
class A
{
private $id;
/** @ORM\ManyToMany(targetEntity="B",inversedBy="list_a") */
private Collection $list_b;
}
class B
{
private $id;
private $type;
/** @ORM\ManyToMany(targetEntity="A",mappedBy="list_b") */
private Collection $list_a;
}
CREATE TABLE A_B(
a_id INT NOT NULL,b_id INT NOT NULL,PRIMARY KEY(a_id,b_id)
) ENGINE = InnoDB;
ALTER TABLE A_B ADD FOREIGN KEY (a_id) REFERENCES A(id);
ALTER TABLE A_B ADD FOREIGN KEY (b_id) REFERENCES B(id);
现在,我要断言A不能有多个具有相同$ type的B并在连接表中添加类似内容:
ALTER TABLE A_B ADD FOREIGN KEY (b_type) REFERENCES B(type);
ALTER TABLE A_B ADD uc_type UNIQUE (a_id,b_type);
所以我想知道是否可以使用教义注释而不必创建第三类?
谢谢
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)