小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
您的位置:首页 > 后端编程 > 数据库 > mysql

mysql实体之间的关系,一对一,一对多,多对一,多对多,以及外键

分类: mysql50个赞

mysql实体之间的关系有以下几种


1、一对一

2、一对多

3、多对一

4、多对多


其中多对一就是一对多意思一样

mysql实体之间的关系一对一

一、一对一

两个实体表内,存在相同的主键字段


如何实现一对一?

主键和主键建关系


思考:一对一两个表完全可以用一个表实现,为什么还要分成两个表?

答:在字段数量很多情况下,数据量也就很大,每次查询都需要检索大量数据,这样效率低下。我们可以将所有字段分成两个部分,“常用字段”和“不常用字段”,这样对大部分查询者来说效率提高了。【优化上称为表的垂直分割】


二、一对多和多对一

主表中的一条记录对应从表中的多条记录;或反之

mysql实体之间的关系多对一和一对多


实现一对多的方式:

主键和非主键建关系


问题:说出几个一对多的环境?

班主任表——学生表

品牌表——商品表



三、多对多

主表中的一条记录对应从表中的多条记录,

从表中的一条记录,对应主表中的多条记


mysql实体之间的关系多对多


如何实现多对多?

利用第三张关系表



问题:说出几个多对多的环境?

讲师表——学生表
课程表——学生表
商品表——订单表



mysql实体关系重点:

如何实现一对一:主键和主键建关系

如果实现一对多:主键和非主键建关系

如何实现多对多:引入第三张关系表



实体关系相关:

外键 foreign key

概念:

如果一个实体(student)的某个字段(student:class_id)指向(引用)另一个实体(class)的主键(class:class_id)

就称student实体的class_id是这两个实体关联的外键。

拓展阅读:mysql外键和外键的三种操作方式


被指向的实体称为主实体(主表),也叫父实体(父表)

负责指向的实体称为从实体(从表),也叫子实体(子表)

一般在哪个表里定义外键 这个表就是子表

外键作用:

约束处于关系内的实体

 增加子表记录时,是否有与之对应的父表记录。删除和更新主表记录时,从表应该如何处理与之相关的记录。


小米技术社区