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日

相关文章

  • mysql 字符串长度计算实现代码(gb2312+utf8)

    当我们需要在 MySQL 数据库中存储字符串时,我们需要先了解字符集和字符串长度计算的规则,以便正确创建和查询数据。下面是 MySQL 中字符串长度计算的实现代码,包括 gb2312 与 utf8 两种字符集。 字符集和字符串长度计算规则 MySQL 中的字符串长度计算与字符集有关。在字符集为 ASCII 的情况下,字符串长度计算即为字符串中字符的个数;而在…

    MySQL 2023年5月19日
    00
  • MySQL MHA信息的收集【Filebeat+logstash+MySQL】

    一.项目背景 随着集团MHA集群的日渐增长,MHA管理平台话越来越迫切。而MHA平台的建设第一步就是将这些成百上千套的MHA集群信息收集起来,便于查询和管理。 MHA主要信息如下: (1)基础配置信息; (2)运行状态信息; (3)启动及FailOver的log信息。 集团目前数据库的管理平台是在Archery的基础上打造,所以,需要将此功能嵌入到既有平台上…

    MySQL 2023年4月16日
    00
  • 关于MySQL实现指定编码遇到的坑

    针对MySQL实现指定编码遇到的坑,我们可以采取以下的攻略: 第一步:确认数据库字符集和排序规则 在MySQL中,字符集和排序规则是非常重要的,因为它们直接影响到数据的存储和查询。因此,在执行任何操作之前,我们需要先确认数据库当前的字符集和排序规则是否符合要求。 我们可以通过如下命令来查看数据库的字符集和排序规则: SHOW VARIABLES LIKE ‘…

    MySQL 2023年5月18日
    00
  • Linux下编译redis和phpredis的方法

    当在Linux下搭建Web应用时,Redis和phpredis扮演了重要的角色。Redis是一个高性能的Key-Value数据库,而phpredis是PHP的扩展,它允许我们用PHP操作Redis。下面我将分享如何在Linux下编译Redis和phpredis的方法。 编译Redis 步骤一:从官网下载Redis源码包 在官网https://redis.io…

    database 2023年5月22日
    00
  • Dlib+OpenCV深度学习人脸识别的方法示例

    我会为您详细讲解“Dlib+OpenCV深度学习人脸识别的方法示例”的完整攻略。 概述 人脸识别是计算机视觉中的一个重要方向,而深度学习技术已经在这个方向中得到广泛应用。本文主要介绍利用Dlib和OpenCV库实现深度学习人脸识别的方法,包括模型训练和测试。 环境搭建 在开始使用Dlib和OpenCV库实现深度学习人脸识别前,需要先安装相关的环境。 1. 安…

    database 2023年5月21日
    00
  • 如何在Python中执行SQLite数据库的查询语句?

    在Python中,我们可以使用sqlite3库执行SQLite数据库的查询语句。以下是如何在Python中执行SQLite数据库的查询语句的完整使用攻略,包括连接数据库、创建游标、执行语句等步骤。同时提供了两个示例以便更好理解如何在Python中执行SQLite数据库的查询语句。 步骤1:安装sqlite3库 在Python中,我们可以使用sqlite3库连…

    python 2023年5月12日
    00
  • sqlserver中Case的使用方法(上下篇)第2/2页

    首先我们需要了解什么是SQL Server的Case语句。Case语句是一种条件语句,通过判断一个或多个条件来决定执行哪一个语句块,类似于if-else结构。Case语句可以有多种不同的形式,其中最常用的形式包括简单Case语句和搜索Case语句。下面我将分别针对这两种形式进行详细讲解。 一、简单CASE语句 简单Case语句用于基于单个条件值执行不同的操作…

    database 2023年5月21日
    00
  • 一文详解MySQL Join使用原理

    一文详解MySQL Join使用原理 MySQL Join 是 SQL 语言中相对复杂的一个命令,用于将不同表中的数据合并在一起。通过 Join 命令,可以将多个表中有关联的数据进行联合查询,从而更加快速、方便地获得我们所需的数据。本文将详细介绍 MySQL Join 的使用原理以及常见类型、操作方法。 Join 的基本概念 Join 是 MySQL 数据库…

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