iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL 外键(FOREIGN KEY)用法案例详解
  • 484
分享到

MySQL 外键(FOREIGN KEY)用法案例详解

MySQL外键MySQLFOREIGNKEY 2022-05-18 22:05:13 484人浏览 独家记忆
摘要

引子:把所有数据都存放于一张表的弊端 表的组织结构复杂不清晰 浪费空间 扩展性极差 为了解决上述的问题,就需要用多张表来存放数据。 表与表的记录之间存在着三种关系:一对多、多对多、一对一的

引子:把所有数据都存放于一张表的弊端

  1. 表的组织结构复杂不清晰
  2. 浪费空间
  3. 扩展性极差

为了解决上述的问题,就需要用多张表来存放数据。

表与表的记录之间存在着三种关系:一对多、多对多、一对一的关系。

处理表之间关系问题就会利用到FOREIGN KEY

多对一关系:

寻找表与表之间的关系的套路

举例:雇员表:emp表   部门:dep表

part1:

  1. 先站在表emp的角度
  2. 去找表emp的多条记录能否对应表dep的一条记录。
  3. 翻译2的意义:
    左表emp的多条记录==》多个员工
    右表dep的一条记录==》一个部门
    最终翻译结果:多个员工是否可以属于一个部门?

            如果是则需要进行part2的流程

part2:

  1. 站在表dep的角度
  2. 去找表dep的多条记录能否对应表emp的一条记录
  3. 翻译2的意义:
    右表dep的多条记录==》多个部门
    左表emp的一条记录==》一个员工

            最终翻译结果:多个部门是否可以包含同一个员工
如果不可以,则可以确定emp与dep的关系只一个单向的多对一
如何实现?
此时就可以用到外键了,在emp表中新增一个dep_id字段,该字段指向dep表的id字段

foreign key会带来什么样的效果?

约束1:在创建表时,先建被关联的表dep,才能建关联表emp


create table dep(
    id int primary key auto_increment,
    dep_name char(10),
    dep_comment char(60)
);
 
create table emp(
    id int primary key auto_increment,
    name char(16),
    gender enum('male','female') not null default 'male',
    dep_id int,
    foreign key(dep_id) references dep(id)
);

约束2:在插入记录时,必须先插被关联的表dep,才能插关联表emp


insert into dep(dep_name,dep_comment) values
('教学部','辅导学生学习,教授课程'),
('公关部','处理公关危机'),
('技术部','开发项目,研究技术');
 
insert into emp(name,gender,dep_id)  values
('monicx0','male',1),
('monicx1','male',2),
('monicx2','male',1),
('monicx3','male',1),
('lili','female',3);

约束3:更新与删除都需要考虑到关联与被关联的关系。

解决方案:

先删除关联表emp,再删除被关联表dep,准备重建

重建:新增功能,同步更新,同步删除


create table dep(
    id int primary key auto_increment,
    dep_name char(10),
    dep_comment char(60)
);
 
create table emp(
    id int primary key auto_increment,
    name char(16),
    gender enum('male','female') not null default 'male',
    dep_id int,
    foreign key(dep_id) references dep(id)
    on update cascade
    on delete cascade
);

此时再去修改:

得到结果:

此时再去删除:

得到结果:

多对多的关系:

两张表记录之间是一个双向的多对一关系,称之为多对多关系。

如何实现?

建立第三张表,该表中有一个字段foreign key左表的id,还有一个字段是foreign key右表的id


create table author(
    id int primary key auto_increment,
    name char(16)
);
 
create table book(
    id int primary key auto_increment,
    bname char(16),
    price int
);
 
insert into author(name) values
('monicx1'),
('monicx2'),
('monicx3')
;
insert into book(bname,price) values
('python入门到入土',200),
('liunx从入门到入土',400),
('java从入门到入土',300),
('PHP从入门到入土',100)
;
#建立第三张表:
create table author2book(
    id int primary key auto_increment,
    author_id int,
    book_id int,
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade,
    foreign key(book_id) references book(id)
    on update cascade
    on delete cascade
);
 
insert into author2book(author_id,book_id) values
(1,3),
(1,4),
(2,2),
(2,4),
(3,1),
(3,2),

一对一关系左表的一条记录唯一对应右表的一条记录,反之也一样


create table customer(
    id int primary key auto_increment,
    name char(20) not null,
    qq char(10) not null,
    phone char(16) not null
);
 
create table student(
    id int primary key auto_increment,
    class_name char(20) not null,
    customer_id int unique, #该字段一定要是唯一的
    foreign key(customer_id) references customer(id) #此时外键的字段一定要保证unique
    on delete cascade
    on update cascade
);

到此这篇关于Mysql 外键(FOREIGN KEY)用法案例详解的文章就介绍到这了,更多相关mysql 外键(FOREIGN KEY)用法内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL 外键(FOREIGN KEY)用法案例详解

本文链接: https://www.lsjlt.com/news/10468.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中的外键(foreign key)
    阅读目录 前言一、外键作用及其限制条件1 外键的定义2 外键的作用3 外键创建限制 二、外键创建方法1 创建外键的语法2 举例(1)创建两张表(2)创建外键(3)查看表结构 三、验证外键作用1 先向主表中添加数据...
    99+
    2023-08-25
    mysql 数据库 java
  • 如何在mysql中使用foreign key创建外键
    如何在mysql中使用foreign key创建外键?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、说明表中的foreign key指向另一表中的primar...
    99+
    2023-06-15
  • mysql新建外键时1215 - Cannot add foreign key constraint错误处理
    1、问题背景 用Navicat在新建表的外键时,弹出如下窗口 2、问题原因 出现上面的的报错,有如下几个因素: (1)外键对应的字段数据类型不一致 (2)设置外键时“删除时”设置为“SET NULL” (3)两张表的存储引擎不一致 3、处...
    99+
    2023-08-16
    mysql 数据库
  • Cannot truncate a table referenced in a foreign key constraint - 如何解决MySQL报错:无法截断被外键约束引用的表
    摘要:在使用MySQL数据库管理系统时,常常遇到无法截断被外键约束引用的表的问题。本文将详细介绍这个错误的原因,并提供解决方案,包括具体的代码示例,帮助读者更好地理解和解决这个问题。正文:引言在数据库设计中,外键是用来建立不同表之间关联的重...
    99+
    2023-10-21
    解决 截断 外键约束
  • java之assert关键字用法案例详解
    Java2在1.4中新增了一个关键字:assert。在程序开发过程中使用它创建一个断言(assertion)。,它的语法形式有如下所示的两种形式: 1、assert con...
    99+
    2024-04-02
  • Cannot add or update a child row: a foreign key constraint fails - 如何解决MySQL报错:子行有外键约束
    在使用MySQL数据库时,我们可能会遇到"Cannot add or update a child row: a foreign key constraint fails"这个错误。这个错误通常表示在插入或更新数据时,出现了外键约束的问题。...
    99+
    2023-10-21
    解决方法 外键约束 MySQL报错
  • Cannot delete or update a parent row: a foreign key constraint fails - 如何解决MySQL报错:父行有外键约束
    在使用MySQL数据库进行开发时,我们经常会遇到一个报错信息:"Cannot delete or update a parent row: a foreign key constraint fails" (无法删除或更新父行:存在...
    99+
    2023-10-21
    MySQL foreign key constraint
  • MySQL数据库中外键的作用及用法详解
    MySQL数据库中外键的作用及用法详解 在MySQL数据库中,外键是用来建立表与表之间关联的重要工具,它能够确保数据完整性,并且提供了一种方式来维护表与表之间的关系。本文将详细介绍My...
    99+
    2024-03-15
    外键 - 关联 用法 - 详解
  • CRITICAL_SECTION用法案例详解
          很多人对CRITICAL_SECTION的理解是错误的,认为CRITICAL_SECTION是锁定了资源,其实,CRITICAL_SECTI...
    99+
    2024-04-02
  • MySQL案例分析讲解外连接语法
    目录前言左连接例 1右连接例2作业记录前言 外连接可以分为左外连接和右外连接 左外连接: 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行 右外连...
    99+
    2024-04-02
  • mysql中关键词exists的用法实例详解
    目录前言语法解释语法说明使用案例环境准备常用查询exists与in的效率比较循环嵌套查询执行原理循环优化策略exists和in查询原理的区别结论总结前言 在日常开发中,用mysql进...
    99+
    2024-04-02
  • MySQL外键设置的方法实例
    一、外键设置方法 1、在MySQL中,为了把2个表关联起来,会用到2个重要的功能:外键(FOREIGN KEY)和连接(JOIN)。外键需要在创建表的阶段定义,连接可以通过相同意义的...
    99+
    2024-04-02
  • MySQL主键约束和外键约束详解
    目录1、PRIMARY KEY2、FOREIGN KEY3、表的设计3.1 一对一3.2 一对多3.3 多对多1、PRIMARY KEY 上期我们讲述了 not null 和 unique 约束,而本期的第一个约束就是这...
    99+
    2023-03-13
    mysql主键约束和外键约束 mysql主键和外键
  • C++ GetDlgItem用法案例详解
    GetDlgItem的用法小结 GetDlgItem用于获得指定控件ID的窗体指针,函数原型如下: HWND GetDlgItem( HWND hDlg, int nI...
    99+
    2024-04-02
  • MySql escape的使用案例详解
    MySQL转义 转义即表示转义字符原来的语义,一个转义字符的目的是开始一个字符序列,使得转义字符开头的该字符序列具有不同于该字符序列单独出现时的语义。 在sql like语句中,比如...
    99+
    2024-04-02
  • Java ConcurrentHashMap用法案例详解
    一、概念 哈希算法(hash algorithm):是一种将任意内容的输入转换成相同长度输出的加密方式,其输出被称为哈希值。 哈希表(hash table):根据设定的哈希函数H(k...
    99+
    2024-04-02
  • C++ ostream用法案例详解
    概述 在 C++中,ostream表示输出流,英文”output stream“的简称。在 C++中常见的输出流对象就是标准输出流cout,很少自定义ostream的对象,更多的是直...
    99+
    2024-04-02
  • C# Request.Form用法案例详解
    在CS文件中获得对应页面中的下拉框DropDownList_sitebranch值可以有以下几种方法获得: siteInfo.FZJGID = DropDownList_site...
    99+
    2024-04-02
  • MFC LoadImage用法案例详解
    目录函数原型cxDesired, cyDesired:fuLoad:示例1.加载Icon资源2.加载本地磁盘的Icon文件3.加载本地磁盘的Bitmap文件函数原型 HANDLE...
    99+
    2024-04-02
  • C# pictureBox用法案例详解
    PictureBox 控件可以显示来自位图、图标或者元文件,以及来自增强的元文件、JPEG 或 GIF 文件的图形。如果控件不足以显示整幅图象,则裁剪图象以适应控件的大小。 本文利用...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作