数据库表 多对多的关系怎么建啊?

数据库表 多对多的关系怎么建啊?,第1张

A表,a_id,a_name,a_tel三个字段。

B表,b_id,b_address,b_sol三个字段。

关联表,ref_id,a_id,b_id,存储着AB两表的id,

比如:A有

a0001,zhang3,139555533

a0002,li4,1397788888

a0003,wang5,13655566

B有

b0001,shanghai,234

b0002,shenyang,332

b0003,chongqing,123

如果想要AB表多对多的话,只需要将关联表进行增加即可,而AB两表基本数据不变,

比如:

关联表ref_table:

r0001,a0001,b0002

r0002,a0001,b0001

r0003,a0001,b0003

r0004,a0002,b0003

通过联合查询,就可以得到多对多的数据了,而且不破坏基本数据表。

数据库实体间有三种关联关系:一对一,一对多,多对多。

一对一实例:一个学生只有个身份z编号。

一对多实例:一个班级有多个学生。

多对多实例:多对多就是双向一对多,一个学生可以选择多门课,一门课也有多名学生。

1

2

3

1

2

3

1.一对多关系处理:

我们以学生和班级之间的关系来说明一对多的关系处理方法。

假设现有基本表学生表(学号,姓名,……),班级表(班级号,备注信息,……)。

1

2

1

2

方法一:

新增一个关系表,用来表示学生与班级的属于关系,该关系表包含字段(学生号,班级号)。通过学生号与班级号的对应关系表示学生属于的班级。

1

1

方法二:

在学生表中新增字段(班级号),该字段作为学生表的外键与班级表中的班级号关联。每一个学生实体在班级号字段的值,表示该学生属于的班级。

1

1

小结:一般情况下,一对多关系采用方法二来处理。一对多的两个实体间,在“多”的实体表中新增一个字段,该字段是“一”实体表的主键。

2.多对多关系处理:

在多对多关系中,我们要新增加一个关系表。如在上面示例中,在学生表和课程表的基础上增加选课表来表示学生与课程之间的多对多关系。在选课表中,必须含有的属性有学生号和课程号。(学生号,课程号)这个属性集刚好也就是选课表的关键字。

1

1

文章知识点与官方知识档案匹配

MySQL入门技能树数据库组成表

29349 人正在系统学习中

打开CSDN,阅读体验更佳

...CaseyWei的博客_实体之间的联系有一对一、一对多

数据库实体间关联关系:一对一、一对多、多对多 数据库实体间有三种对应关系:一对一,一对多,多对多。 一对一关系示例:一个学生对应一个学生档案材料,或者每个人都有唯一的身份z编号。 一对多关系示例:一个学生只属于一个班,但是一个...

继续访问

...库中两个实体集之间的联系有一对一、一对多和多对多

数据库实体间三种对应关系:一对一,一对多,多对多。 ps:本人亲测,阿里云2核4G5M的服务器性价比很高,新用户一块多一天,老用户三块多一天,最高可以买三年,感兴趣的可以戳一下:阿里云折扣服务器 一对一关系示例:一个学生对应一个学生...

继续访问

最新发布 什么是数据库中的一对多关系?

但是,如果您忘记了存储所有信息的表,并想象实际上有不同的表,每个表都代表层次结构中的一个级别,则可视化起来会更容易一些。实际


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6672995.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存