数据库表结构导出工具【人生的第一个开源工具】

news/2024/7/5 4:05:30

数据库表结构导出工具

在这里插入图片描述

如今我努力奔跑,不过是为了追上那个曾经被寄予厚望的自己 —— 约翰。利文斯顿

本工具是一个用于将数据库表结构导出到 Word 文档的实用工具。它能够连接到指定的数据库,提取数据库中所有表的结构信息,并将这些信息以专业的方式整理并保存到一个易于阅读和分享的文档中。

功能特点

  • 数据库连接验证:提供了测试连接功能,确保用户输入的数据库连接信息准确无误,确保成功连接到目标数据库。
  • 数据结构导出:能够自动从数据库中提取所有表的结构信息,包括表名称、字段名称、数据类型和字段注释等,并将其整理到一个规范的 Word 文档中。
  • 用户友好界面:采用直观清晰的用户界面设计,使用户可以轻松输入数据库连接信息和文件保存路径,并通过简单的按钮操作完成数据结构导出。

使用方法

  1. 克隆本仓库到本地计算机:

    git clone https://gitee.com/wanghui1201/Data-Dictionary-Export-utils.git
    
  2. 安装依赖

    pip install sqlalchemy docx
    
  3. 运行主程序

    python App.py
    
  4. 在打开的界面中,输入数据库的连接信息和文件存储路径,然后点击 “测试连接” 按钮检查连接是否成功。如果连接成功,点击 “导出文档” 按钮即可导出数据库中所有表的结构信息到 Word 文档中。

核心源码

# 数据库连接
def get_table_fields(ip, database, username, password):
    try:
        # 构建数据库连接字符串
        db_url = f"mysql://{username}:{password}@{ip}/{database}?charset=utf8mb4"
        # 创建数据库引擎
        engine = create_engine(db_url)
        # 创建元数据对象
        metadata = MetaData(bind=engine)
        # 反射表结构
        metadata.reflect()
        # 获取所有的表结构
        tables = metadata.tables
        return tables
    except Exception as e:
        return str(e)
        
# 获取所有的表对象
def get_all_table_structure(tables):
    # 定义所有表的结构信息字典
    all_tables_info = {}
    # 遍历所有表,获取所有表的结构
    for table_name, table in tables.items():
        table_info = []
        for column in table.columns:
            field_info = {
                "name": column.name,
                "type": str(column.type),
                "comment": column.comment if hasattr(column, 'comment') else None
            }
            table_info.append(field_info)
        all_tables_info[table_name] = table_info
    return all_tables_info

程序界面

在这里插入图片描述

在这里插入图片描述

产品测试

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

注意事项

  • 确保已经正确安装了 Python 3 环境。
  • 确保输入的数据库连接信息正确,包括 IP 地址、数据库名称、用户名和密码。
  • 导出的 Word 文档将保存在指定的文件存储路径中,文件名为 “数据结构.docx”。

通过本工具,您可以轻松快速地了解和分享数据库中的表结构信息,为团队协作和数据库管理提供便利。欢迎使用并提出宝贵意见和建议,让我们不断改进和完善本工具。


http://lihuaxi.xjx100.cn/news/2100984.html

相关文章

Linux之shell文本搜索工具grep

华子目录 文本搜索工具grep作用格式参数注意示例 正则表达式概念基本正则表达式常见元字符posix字符类示例 扩展正则表达式概念元字符示例三种支持扩展正则的方法 文本搜索工具grep 作用 grep是linux中一种强大的文件搜索过滤工具,可以按照正则表达式检索文件内容…

UG NX二次开发(C++)-CAM-获取加工操作的四种方法

文章目录 1、前言2、采用选中工序导航器获取操作的Tag_t3、采用遍历对象的方法获取操作的Tag_t4、采用Collection遍历获取操作对象NXOpen::CAM::Operation5、采用FindObject获取操作对象NXOpen::CAM::Operation6、以上4种方法封装成类 Class CAMOperation6.1 CAMOperation.h文件…

用pako.js压缩字符串,如何在后端用java解开?

背景:项目链路为腾讯clb->Ingress(nginx)->项目服务,腾讯的Ingress对header请求头最大值为256K,无法加大,由于业务配置数据增加,此问题诟病已久,于是想着压缩打请求头数据后再请求,从而解决请求头大的…

一套为中小电商企业构建的、开源的、简单实用的ERP系统需要接入的电商API接口以及实现的功能模块分析

一、项目简介 电商ERP系统为中小电商企业构建的一套简单实用的电商系统,本项目采用Java SpringBootVue2前后端分离开发。 支持供应商一件代发和仓库发货两种发货方式,主体流程覆盖采购、网店订单处理、供应商一件代发、仓库发货、网店售后、仓库出入库、…

[C++] 实现Union

前几天学了replacement new写的小玩意 #include <iostream> #include <functional> #include <string>// 可能因为const char*类型的缘故 // 用const ArgsT&&...会报错// 测试用类 struct Test {Test(){std::cout << "constructed"…

Unity2019.2.x 导出apk 安装到安卓Android12+及以上的系统版本 安装出现-108 安装包似乎无效的解决办法

Unity2019.2.x 导出apk 安装到安卓Android12及以上的系统版本 安装出现-108 安装包似乎无效的解决办法 导出AndroidStudio工程后 需要设置 build.gradle文件 // GENERATED BY UNITY. REMOVE THIS COMMENT TO PREVENT OVERWRITING WHEN EXPORTING AGAINbuildscript {repositor…

【洛谷 P8602】[蓝桥杯 2013 省 A] 大臣的旅费 题解(图论+深度优先搜索+树的直径+链式前向星)

[蓝桥杯 2013 省 A] 大臣的旅费 题目描述 很久以前&#xff0c;T 王国空前繁荣。为了更好地管理国家&#xff0c;王国修建了大量的快速路&#xff0c;用于连接首都和王国内的各大城市。 为节省经费&#xff0c;T 国的大臣们经过思考&#xff0c;制定了一套优秀的修建方案&am…

sqllab第二十六关通关笔记

知识点&#xff1a; 空格替换 %09 %0a %0b %0c %0d %a0 (%2b)or替换&#xff1a;|| ||是不需要空格区分的and替换&#xff1a;&& &&同样不需要空格区分的双写绕过&#xff0c;但是绕过后需要和内容进行空格区分的&#xff0c;要不然不发挥作用&#xff1b;这关…