微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

原则-多对多具有独特的约束

如何解决原则-多对多具有独特的约束

我正在尝试在两个类之间建立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 举报,一经查实,本站将立刻删除。