如何获取 mysql 外键索引的元数据信息?

背景

对数据进行统一的管理处理,后续方便使用。

基本信息

见上一篇的处理。

sql 复制代码
select * from information_schema.KEY_COLUMN_USAGE where REFERENCED_TABLE_SCHEMA = 'test' \G;

*************************** 1. row ***************************
           CONSTRAINT_CATALOG: def
            CONSTRAINT_SCHEMA: test
              CONSTRAINT_NAME: user_extra_ibfk_1
                TABLE_CATALOG: def
                 TABLE_SCHEMA: test
                   TABLE_NAME: user_extra
                  COLUMN_NAME: user_id
             ORDINAL_POSITION: 1
POSITION_IN_UNIQUE_CONSTRAINT: 1
      REFERENCED_TABLE_SCHEMA: test
        REFERENCED_TABLE_NAME: users
       REFERENCED_COLUMN_NAME: id
1 row in set (0.06 sec)

字段解释

这是一个查询信息模式(information_schema)中的关键列使用情况的SQL语句,通过指定条件REFERENCED_TABLE_SCHEMA = 'test'筛选了特定的数据库(test)。

下面是查询结果的详细解释:

  1. CONSTRAINT_CATALOG: 表示外键约束所属的目录,这里是默认值 "def"。

  2. CONSTRAINT_SCHEMA: 表示外键约束所属的数据库,这里是 "test"。

  3. CONSTRAINT_NAME: 表示外键约束的名称,这里是 "user_extra_ibfk_1"。

  4. TABLE_CATALOG: 表示表所属的目录,这里是默认值 "def"。

  5. TABLE_SCHEMA: 表示表所属的数据库,这里是 "test"。

  6. TABLE_NAME: 表示表的名称,这里是 "user_extra"。

  7. COLUMN_NAME: 表示表中的列名,这里是 "user_id"。

  8. ORDINAL_POSITION: 表示列在表中的顺序位置,这里是第1列。

  9. POSITION_IN_UNIQUE_CONSTRAINT: 表示在唯一约束中的位置,这里是第1个位置。

  10. REFERENCED_TABLE_SCHEMA: 表示被引用表所属的数据库,这里是 "test"。

  11. REFERENCED_TABLE_NAME: 表示被引用表的名称,这里是 "users"。

  12. REFERENCED_COLUMN_NAME: 表示被引用表中的列名,这里是 "id"。

这个查询的结果告诉我们,在数据库 "test" 中,表 "user_extra" 中的 "user_id" 列是一个外键,它参照了表 "users" 中的 "id" 列,外键的约束名称为 "user_extra_ibfk_1"。

本文由博客一文多发平台 OpenWrite 发布!

相关推荐
泡泡以安2 小时前
【Android逆向工程】第3章:Java 字节码与 Smali 语法基础
android·java·安卓逆向
毕设源码-朱学姐7 小时前
【开题答辩全过程】以 工厂能耗分析平台的设计与实现为例,包含答辩的问题和答案
java·vue.js
Spring AI学习8 小时前
Spring AI深度解析(9/50):可观测性与监控体系实战
java·人工智能·spring
java1234_小锋9 小时前
Spring IoC的实现机制是什么?
java·后端·spring
xqqxqxxq10 小时前
背单词软件技术笔记(V2.0扩展版)
java·笔记·python
消失的旧时光-194310 小时前
深入理解 Java 线程池(二):ThreadPoolExecutor 执行流程 + 运行状态 + ctl 原理全解析
java·开发语言
哈哈老师啊10 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
4311媒体网10 小时前
帝国cms调用文章内容 二开基本操作
java·开发语言·php
zwxu_10 小时前
Nginx NIO对比Java NIO
java·nginx·nio
可观测性用观测云12 小时前
Pyroscope Java 接入最佳实践
java