
多对多:新建一个关系表,将两张表关系起来。关系表中是两张表的主键。
如:有多个学生,每个学生可以选修多门课程,每个课程可以被多个学生选修。
注意:多对多中,不能说在一个表中加个字段,cid是另一张表的主键,不能写两个数据。
扩展资料
一个好的表结构设计,可以减少一些不必要的表或字段等。数据表之间的关联关系分为三种:一对一、一对多、多对多。
1、一对一,是将数据表“垂直切分”,就是A表的一条记录对应B表的一条记录。
优点:
(1)便于管理、可提高一定的查询速度。
(2)减轻CPU的IO读写,提高存取效率。
(3)符合数据库设计的三大范式。
(4)符合关系性数据库的特性。
缺点:增加一定的复杂程度,程序中的读写难度加大。
2、一对多,就是A表的一条记录,对应B表的多条记录,且A的主键作为B表的外键。
有两种办法:第一种方法是通过外键:
假设有两张表,
A表(AId,AName) B(BId,BName)表 ,要想把这两者关联起来的话。可以通过外键来关联,在B表或者A表中添加一个外键。这里就以B表把B(BId,AId(外键),BName),这样通过外键两张表就可以联系起来了,例如我们在查询的时候通过AId就可以关联查询两张表的数据了。
第二种方法就是增加一张表:
还是拿A表(AId,AName) B(BId,BName)表来举例把,
我们可以增加个C表来联系AB表之间的关系
C表中只要放AB表的主键就行了
C(AId,BId),这样我们就可以通过C表来关联AB表了。
呵呵
多对多 的情况下, 需要一个中间关联表
例如下图:
一个用户,可以有多个角色,
一个角色下面, 有多个用户。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)