MySQL外键约束(FOREIGN KEY)详解

MySQL的外键约束是一种保证数据完整性的机制,它可以强制要求一个列或列组合与另一张表中的数据匹配。外键约束规定了在一个表中某个列的值必须是另一张表中某个列的值。

外键约束的作用

  1. 可以确保数据的完整性,防止插入无效数据;
  2. 在删除或更新主表数据时,自动删除或更新关联的子表数据,便于维护数据一致性;

外键约束使用方法

创建外键约束语法:
CREATE TABLE 子表名 (
子表列1 数据类型,
子表列2 数据类型,
...
FOREIGN KEY (子表列1) REFERENCES 主表名(主表列1)
);

示例:

CREATE TABLE department (
dept_id INT PRIMARY KEY,
dept_name VARCHAR(50) NOT NULL
);

CREATE TABLE employee (
emp_id INT PRIMARY KEY,
emp_name VARCHAR(50) NOT NULL,
salary INT,
dept_id INT,
FOREIGN KEY (dept_id) REFERENCES department(dept_id)
);

这个例子中,employee表中的dept_id列是department表中的主键dept_id的外键。这意味着任何时候,employee表中的dept_id的值必须是department表中dept_id的一个有效值。

示例2:

CREATE TABLE publisher (
publisher_id INT PRIMARY KEY,
publisher_name VARCHAR(50) NOT NULL
);

CREATE TABLE book (
book_id INT PRIMARY KEY,
book_title VARCHAR(50) NOT NULL,
publisher_id INT,
FOREIGN KEY (publisher_id) REFERENCES publisher(publisher_id) ON UPDATE CASCADE ON DELETE SET NULL
);

在这个例子中,book表中的publisher_id列也是publisher表中的主键publisher_id的外键。如果publisher表的publisher_id被更新或删除,book表的对应行也会被更新或删除。如果更新后的外键值对应着一个不存在的记录,则book表对应行的外键值将变为NULL。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:MySQL外键约束(FOREIGN KEY)详解 - Python技术站

(0)
上一篇 2023年3月9日
下一篇 2023年3月9日

相关文章

  • PHP5中使用mysqli的prepare操作数据库的介绍

    当使用PHP操作数据库时,为了避免向数据库中执行错误的SQL语句,使用查询准备和指定查询参数,这就是mysqli的prepare操作。 下面是使用mysqli的prepare操作数据库的完整攻略: 1. 连接数据库 首先,我们需要连接数据库,可以使用mysqli_connect()函数实现。代码示例如下: $connection = mysqli_conne…

    database 2023年5月21日
    00
  • windows下php安装redis扩展

    查看当前PHP版本 代码中添加 phpinfo(); 下载对应的redis扩展 下载链接:https://pecl.php.net/package/redis因为我的PHP版本是5.6的,所以redis版本对应2.2.7。下载redis扩展文件并解压 安装redis扩展 将解压后的php_redis.dll文件放到php的ext目录下 修改php.ini文件…

    Redis 2023年4月13日
    00
  • mysql实现设置定时任务的方法分析

    下面是“MySQL实现设置定时任务的方法分析”的详细攻略。 一、背景 在实际的数据库管理中,经常需要执行一些定时任务,如每天备份数据、定时清理数据等。MySQL作为一种常见的关系型数据库,也提供了设置定时任务的方法。 二、MySQL设置定时任务的方法 1. 使用MySQL事件(Event) MySQL的事件(Event)是一种基于时间的操作,类似于操作系统中…

    database 2023年5月22日
    00
  • 浅谈SpringBoot集成Redis实现缓存处理(Spring AOP实现)

    下面我将为您详细讲解SpringBoot集成Redis实现缓存处理的完整攻略,过程中将提供两条示例说明。 一、背景 SpringBoot是目前在Java开发领域中应用最为广泛的一种开发框架。而Redis则是目前使用最为广泛的一款内存缓存技术。在SpringBoot中集成Redis实现缓存处理,会大大提高网站的性能。 二、具体实现步骤 引入Redis相关的依赖…

    database 2023年5月22日
    00
  • SQL Server数据库基本概念、组成、常用对象与约束

    本文将为大家介绍SQL Server数据库的基本概念、组成、常用对象与约束。SQL Server是微软公司开发的关系型数据库管理系统,支持跨平台使用,是常见企业级数据库系统之一。 SQL Server数据库基本概念 SQL Server数据库包括服务器和数据库两个层次,服务器包含多个数据库。数据库是一种用于保存和管理数据的结构化的、可持久化的数据容器。 SQ…

    database 2023年5月18日
    00
  • php简单的分页程序第5/5页

    下面我将为您详细讲解“PHP简单的分页程序第5/5页”的完整攻略,包括分页程序的原理、实现步骤以及具体的代码示例。 分页程序原理 分页程序的原理很简单,就是将数据分为多个页面显示,让用户可以方便的查看和跳转。具体来说,分页程序需要以下几个步骤: 获取总记录数 在使用分页程序之前,需要先获取总的记录数,这样才能确定要分成多少页。通常可以使用SQL语句如下: S…

    database 2023年5月21日
    00
  • Mysql写入数据十几秒后被自动删除了如何解决

    问题说明: 在使用Mysql时,有时会出现写入数据成功,但是过了十几秒后数据却自动被删除的情况。这种问题可能是由于Mysql有一个默认设置,在某些情况下会自动回滚事务,导致数据被删除。此时可以通过更改Mysql的设置来解决这个问题。 解决步骤: 编辑Mysql配置文件 首先需要编辑Mysql的配置文件my.cnf。找到[mysqld]部分,将innodb_r…

    database 2023年5月22日
    00
  • Mysql优化方法详细介绍

    Mysql优化方法详细介绍 优化Mysql是提高网站性能的重要手段之一。本文将从以下几个方面详细介绍Mysql的优化方法。 1. 确认是否存在慢查询 Mysql的慢查询是导致性能下降的主要原因之一。可以通过查看慢查询日志来确认是否存在慢查询。如果存在慢查询,应该分析优化慢查询,提高查询效率。 示例: # 开启慢查询日志 set global slow_que…

    database 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部