当前位置: 首页 > MySQL数据库

mysql如何查询外键约束

时间:2026-01-27 10:39:59

在mysql中,可以利用show语句查询外键约束,show语句可以显示mysql中的数据库、表和列的信息,语法为“SHOW CREATE TABLE 表名”;该语句可以显示表中所有的主键约束、外键约束、非空约束等所有约束的信息。

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql怎么查询外键约束

mysqlshow 命令用于显示 MySQL 服务器中的数据库、表和列信息。

在 MySQL 中可以使用 SHOW CREATE TABLE 语句来查看表中的约束,进而查询外键约束情况。

查看数据表中的约束语法格式如下:

SHOW CREATE TABLE <数据表名>;

示例如下:

mysql> CREATE TABLE tb_emp8    -> (    -> id INT(11) PRIMARY KEY,    -> name VARCHAR(22) UNIQUE,    -> deptId INT(11) NOT NULL,    -> salary FLOAT DEFAULT 0,    -> CHECK(salary>0),    -> FOREIGN KEY(deptId) REFERENCES tb_dept1(id)    -> );Query OK, 0 rows affected (0.37 sec)mysql> SHOW CREATE TABLE tb_emp8 \G*************************** 1. row ***************************       Table: tb_emp8Create Table: CREATE TABLE `tb_emp8` (  `id` int(11) NOT NULL,  `name` varchar(22) DEFAULT NULL,  `deptId` int(11) NOT NULL,  `salary` float DEFAULT '0',  PRIMARY KEY (`id`),  UNIQUE KEY `name` (`name`),  KEY `deptId` (`deptId`),  CONSTRAINT `tb_emp8_ibfk_1` FOREIGN KEY (`deptId`) REFERENCES `tb_dept1` (`id`)) ENGINE=InnoDB DEFAULT CHARSET=gb23121 row in set (0.19 sec)

扩展知识:

外键约束的定义

Mysql外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)

假设我们有2个表,分别是表A和表B,它们通过一个公共字段“id”发生关联关系,我们把这个关联关系叫做R。如果“id”在表A中是主键,那么,表A就是这个关系R中的主表。相应的,表B就是这个关系中的从表,表B中的“id”,就是表B用来引用表A中数据的,叫外键。所以,外键就是从表中用来引用主表中数据的那个公共字段

外键约束的作用

外键约束,可以帮我们确定从表中外键字段与主表中的主键字段之间的引用关系,还可以确保从表中数据所引用的主表数据不会被删除,确保两个表中数据的一致性

主表删除某条记录时,从表中与之对应的记录也必须有相应的改变。一个表可以有一个或多个外键,外键可以为空值,若不为空值,则每一个外键的值必须等于主表中主键的某个值

但是,外键约束是有成本的,需要消耗系统资源,可能不适合大并发的SQL操作。因此mysql允许你不使用系统自带的外键约束,在应用层面完成检查数据一致性的逻辑。这也是为什么我们即使没有设置外键,也能进行关联查询的原因


上一篇:mysql中replace替换如何用
下一篇:mysql然后修改字段的字符集
mysql
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素