美文网首页
生成并导出MySQL数据字典

生成并导出MySQL数据字典

作者: 风静花犹落 | 来源:发表于2019-12-06 15:57 被阅读0次

代码地址: https://github.com/jayknoxqu/data-dictionary

方式一、通过SQL生成数据字典

USE information_schema;
SELECT
    T.TABLE_SCHEMA AS '数据库名称',
    T.TABLE_NAME AS '表名称',
    T.TABLE_COMMENT AS '表说明',
    T.TABLE_TYPE AS '表类型',
    T.ENGINE AS '数据库引擎',
    C.ORDINAL_POSITION AS '序号',
    C.COLUMN_NAME AS '字段名',
    C.COLUMN_TYPE AS '数据类型',
    C.IS_NULLABLE AS '允许为空',
    C.EXTRA AS '自增属性',
    C.CHARACTER_SET_NAME AS '编码名称',
    C.COLUMN_DEFAULT AS '默认值',
    C.COLUMN_COMMENT AS '字段说明' 
FROM
    COLUMNS C
    INNER JOIN TABLES T ON C.TABLE_SCHEMA = T.TABLE_SCHEMA 
    AND C.TABLE_NAME = T.TABLE_NAME 
WHERE
    T.TABLE_SCHEMA = 'websitedev'

生成样例

数据字典

导出结果

导出结果

缺点: 排版和样式一团糟,所有表字段全部一个表格里,阅读困难

方式二、通过Python生成数据字典

def generate(database_name):
    """
    生成数据库字典表
    """
    importlib.reload(sys)

    # 使用前修改配置
    conn = mysql.connector.connect(
        host='127.0.0.1',
        port='3306',
        user='root',
        password='123456',
        use_pure=True
    )

    cursor = conn.cursor()

    cursor.execute(
        "SELECT TABLE_NAME, TABLE_COMMENT FROM information_schema.TABLES WHERE table_type='BASE TABLE' AND TABLE_SCHEMA='%s'" % database_name
    )

    tables = cursor.fetchall()

    markdown_table_header = """\n\n\n### %s (%s) \n| 序号 | 字段名称 | 数据类型 | 是否为空 | 字段说明 |\n| :--: |----| ---- | ---- | ---- |\n"""
    markdown_table_row = """| %s | %s | %s | %s | %s |"""

    f = open(database_name + '.md', 'w')

    for table in tables:

        cursor.execute(
            "SELECT ORDINAL_POSITION, COLUMN_NAME, COLUMN_TYPE, IS_NULLABLE, COLUMN_COMMENT "
            "FROM information_schema.COLUMNS WHERE TABLE_SCHEMA='%s' AND TABLE_NAME='%s'" % (
                database_name, table[0]
            )
        )

        tmp_table = cursor.fetchall()
        p = markdown_table_header % (table[0], remove_newline(table[1]))
        for col in tmp_table:
            p += (remove_newline(markdown_table_row % col) + "\n")
        print(p)
        f.writelines(p)

    f.close()

生成样例

通过Python生成的markdown文档,可以使用功能强大的Typora编辑器打开,也可以通过该编辑器生成不同类型的文档

数据字典

导出结果

导出结果

相关文章

网友评论

      本文标题:生成并导出MySQL数据字典

      本文链接:https://www.haomeiwen.com/subject/bojegctx.html