自学内容网 自学内容网

Mysql、Dm8达梦数据库通过脚本导出指定库所有表的结构详情信息到

前言

在当今复杂多变的数据环境中,数据库作为信息存储与管理的核心,其重要性不言而喻。随着业务的不断拓展和深化,对于数据库表结构的理解与管理成为了确保数据一致性和准确性的关键。特别是在跨数据库系统的场景下,如何高效地获取并对比不同数据库中的表字段详情,成为了众多开发者与数据管理员面临的一大挑战。


  • 目标描述
    为了满足这一迫切需求,我们特此整理了MySQL和DM8(达梦数据库8)的表字段详情导出方案。MySQL,作为开源数据库领域的佼佼者,以其灵活性和广泛的社区支持而深受欢迎;而DM8,作为国产数据库的杰出代表,则在安全性、稳定性和性能优化方面有着显著的优势。两者各具特色,广泛应用于不同的业务场景中。
  • 目标展示(数据库)
    在这里插入图片描述
  • 目标展示(Excel)
    在这里插入图片描述

二、Mysql

SELECT
TABLE_NAME 表名,
COLUMN_NAME 字段名称,
DATA_TYPE 字段类型,
CHARACTER_MAXIMUM_LENGTH 长字段度,
IF( IS_NULLABLE = 'YES', '是', '否' ) 是否非空,
IF( column_key = 'PRI', '是', '否' ) 是否为主键,
COLUMN_DEFAULT 默认值,
COLUMN_COMMENT 注释 
FROM
INFORMATION_SCHEMA.COLUMNS 
WHERE
table_schema = '替换你的库名称' 

-- 可以精确到表 WHERE追加 `AND TABLE_NAME`

三、达梦8

SELECT 
A.TABLE_NAME 表名, 
A.COLUMN_NAME 字段名称, 
A.DATA_TYPE 字段类型, 
A.DATA_LENGTH 类型长度, 
(CASE WHEN (A.DATA_PRECISION IS NULL) THEN 0 ELSE A.DATA_PRECISION END) 整数位,
A.DATA_SCALE 小数位, 
(CASE WHEN (A.NULLABLE = 'N') THEN '是' ELSE '否' END) 是否非空,
SS.COMMENTS 注释
FROM DBA_TAB_COLUMNS A
INNER JOIN ALL_COL_COMMENTS SS
ON SS.COLUMN_NAME = A.COLUMN_NAME AND SS.TABLE_NAME = A.TABLE_NAME
WHERE A.OWNER='替换你的模式名称';

-- 可以精确到表 WHERE追加 `AND A.TABLE_NAME`

执行sql之后剩下的就是把结果集导出Excel了

本次整理旨在通过系统化的方法,将MySQL和DM8中的表字段信息以清晰、易读的方式呈现出来。我们深入研究了这两种数据库的元数据管理机制,利用SQL查询语句从系统表中提取了详尽的表字段信息,包括字段名称、数据类型、是否允许为空、默认值、注释等关键属性。同时,我们还考虑了主键、外键等约束条件,以确保导出的字段详情能够全面反映数据库表结构的真实面貌。


原文地址:https://blog.csdn.net/qq_42818496/article/details/143600768

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!