推广

【数据库技术】【MySQL】多表基础

iseeyu2年前 (2024-02-21)推广127

MySQL-理解外键举例

看到在表格中有“毕业生类别”这一列,这一列没有采用中文文字的形式表述,而是采用的“序号”这种方式并且表格最后给予“解释序号含义的注释”。而这实际上就能够体现“外键”这一概念。将最后的备注也看成一张独立的表的话,主键就是“序号”。

  • MySQL 中实现外键约束
-- table_name 从表表名
-- another_table_name 主表表名
-- field_name 从表中的作为外键的字段名
-- primary_key_field_name 主表中的主键字段名
CREATE TABLE table_name (
······
[CONSTRAINT foreign_key_name] FOREIGN KEY(field_name) REFERENCES another_table_name(primary_key_field_name)
);

-- 另一种写法
CREATE TABLE table_name (
······
[CONSTRAINT] FOREIGN KEY [foreign_key_name](field_name) REFERENCES another_table_name(primary_key_field_name)
);
-- 在一张表中添加外键
ALTER TABLE table_name
ADD [CONSTRAINT foreign_key_name] FOREIGN KEY(field_name) REFERENCES another_table_name(primary_key_field_name);

-- 另一种写法
ALTER TABLE table_name
ADD [CONSTRAINT] FOREIGN KEY [foreign_key_name](field_name) REFERENCES another_table_name(primary_key_field_name);
-- 删除外键
ALTER TABLE table_name
DROP FOREIGN KEY foreign_key_name;
  • 外键约束的注意事项:

1、一张表中可以有多个外键约束,但是主键约束最多只能有一个。
2、从表中外键的数据类型、长度必须与主表中的主键数据类型、长度一致,否则创建失败。
3、添加数据时,应该先添加主表中的数据。
4、删除数据时,应该先删除从表中的数据。
5、外键的取值要么是参照主表中的主键的值,要么是NULL(在外键字段没有设置非空约束的情况下,可以取NULL;如果设置非空约束,NULL就不允许)。

  • 级联删除&级联更新

外键约束势必带来的题就是,如果主表发生变动(“变动”是指主表的主键被更新或被删除)从表该怎么办(从表中参照主键的外键该怎么办)。

在创建外键约束的时候,可以进行显式指定:

-- ON UPDATE 主表的主键被更新时从表的外键怎么做
-- ON DELETE 主表的主键被删除时从表的外键怎么做

-- RESTRICT 限制,当在主表中删除对应记录时,首先检查该记录在从表中是否有对应外键,如果有则不允许删除
-- NO ACTION 在 MySQL 中同 RESTRICT
-- CASCADE 级联,主表中主键改变,从表中对应的外键跟着改变
-- SET NULL 设置空值,前提是外键字段不能有非空约束
CREATE TABLE table_name (
······
[CONSTRAINT foreign_key_name] FOREIGN KEY(field_name) REFERENCES another_table_name(primary_key_field_name)
[ON UPDATE [RESTRICT|NO ACTION|CASCADE|SET NULL]]
[ON DELETE [RESTRICT|NO ACTION|CASCADE|SET NULL]];

默认即不显式ON UPDATEON DELETE情况下,是ON UPDATE RESTRICTON DELETE RESTRICT

3、多表关系

  • 多表之间的关系基于的是关系型数据库理论。关系(relation)的产生是需要实体(entity)的支撑的。
    实体,是现实中的事物,实体在数据库中一般情况下可以映射成为一张表。
    多表关系的基础是实体关系。实体之间有什么样的关系基本上对应着表之间有什么样的关系。
    实体间的关系可以使用一种叫作 ER 图的方式表示。

  • 假设有实体 A 和实体 B,两个实体间的关系大致分为“一对一”、“一对多”、“多对多”。

“一对一”:一个实体 A 只对应一个实体 B,一个实体 B 也只能对应一个实体 A。
举例:人与身份证
对于“一对一”关系,可以选择将两个实体的属性合并成在一张表中;也可以分别建立表,然后其中一方设立参照另一方主键的外键即可;甚至可以分别建表,相应行的主键取值完全一致。

“一对一” ER 图表示

“一对多”:一个实体 A 可以对应多个实体 B,但一个实体 B 只能对应一个实体 A。
举例:我国的省市,一个省下面有许多市,而一个市只能隶属于一个省。
对于“一对多”关系,两个实体需要单独建表,其中在“多方”,建立外键参照“一方”的主键。

“一对多” ER 图表示

“多对多”:一个实体 A 可以对应多个实体 B,一个实体 B 也能对应一个实体 A。
举例:学生与课程,一个学生可以有多门课程,而一门课程可以有多个学生。
对于“多对多”关系,两个实体需要单独建表,然后需要创建一个中间表来表示“关系”,中间表的主键是由两个实体主键字段组成的联合主键,然后联合主键中的每一个字段又是外键参照两个实体的主键。

“多对多” ER 图表示

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57574.html

相关文章

更换服务器影响seo吗。

更换服务器影响seo吗。

 网站站服务器出现故障,或者服务器使用容量不够,网站受到攻击导致网站无法打开等,我们都需要更换服务器,但更换服务器对我们的网站仍有一定的影响,我们在更换服务器时必须正确操作,将影响降到最低。 那么怎样转移服务器才是正确的方式呢? 1、提前进行充分备份,包括文本,图片,音乐,视频,程序,数据和相关...

干货+案例| 3个方法让活动营收翻倍!

干货+案例| 3个方法让活动营收翻倍!

  最近我在思考一个问题,对于一个企业来说,到底是流量重要,还是营收重要?都重要,只是流量的目的是为营收服务。而今天要分享的干货,我们就说钱。简单粗暴点:3个方法拿来即用。帮助企业有效提升营收。虽然每一个方法背后都有它的理论支撑,就是消费心理学。但是,我会尽量以案例实操的方式呈...

淘宝店铺释放后多久可以注销(淘宝店铺彻底释放是指店铺注销了嘛)

淘宝店铺释放后多久可以注销(淘宝店铺彻底释放是指店铺注销了嘛)

在淘宝上开店之后如果不想继续做了,这个时候可以把店铺注销或者直接卖出去,如果是才做没多久的淘宝店是卖不了什么钱的,这个时候只能选择去注销了,那么店铺在释放之后多久可以完全注销呢?...

小编教你美光科技第一财季营收51亿美元。

小编教你美光科技第一财季营收51亿美元。

新浪科技讯北京时间12月19日凌晨消息,美光科技今日发布了该公司的2020财年第一财季财报。报告显示,美光科技第一财季营收为51.44亿美元,与去年同期的79.13亿美元相比下降35%;净利润为4.91亿美元,与去年同期的32.93亿美元相比下降85%。美光科技第一财季业绩超出华尔街分析师预期,从而...

如何避免SEO优化中不利因素的影响。

如何避免SEO优化中不利因素的影响。

SEO优化是一把剑。如果使用得当,可以给网站带来无限的利益。使用不当可能会导致网站被K。但是,只要你能掌握一些SEO优化技术,避免一些有害的SEO优化因素的影响,那么你的网站可以排名在百度搜索结果页面的前面。那么什么因素不利于SEO优化呢?站长应该如何避免这些因素? 原因有很多。当网站被百度降权时...

咱们了解的网站内容为什么不稳定呢。

咱们了解的网站内容为什么不稳定呢。

网站内容是最基本相同也是最重要的影响要素。可能是网页使用了很多js、结构代码,使得引擎无法抓取,可能是文章收集严峻回绝录入,也可能是结构逻辑紊乱蜘蛛无法顺畅匍匐等。这些都是咱们能够操控的方面。 在不断优化网站的过程中,咱们能够以访问者停留时间与跳出率为衡量标准,一旦这两个要素有所改善...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片