专业游戏门户,分享手游网游单机游戏百科知识攻略!

嗨游网
嗨游网

如何快速生成MySQL数据库关系图

来源:小嗨整编  作者:小嗨  发布时间:2024-03-20 08:32
摘要:需求描述:在公司老旧系统里,数据库表很多,但是在设计之初并没有建立好关系图,导致新人刚入职,面对n个库,每个库几百张表,很不方便。例如:公司某一个系统的库有三百张表,在不熟悉项目的情况下,打开数据库看到一列列的表,很不清晰,对新入职同事很不...
需求描述:

在公司老旧系统里,数据库表很多,但是在设计之初并没有建立好关系图,导致新人刚入职,面对n个库,每个库几百张表,很不方便。

如何快速生成MySQL数据库关系图

例如:公司某一个系统的库有三百张表,在不熟悉项目的情况下,打开数据库看到一列列的表,很不清晰,对新入职同事很不友好。

需求分析:

我们一个系统里,可能有很多个模块,例如商城系统中有商品模块、券模块、店铺模块等,没个模块都有几十张表,每个模块需要生成如下关系图:(吐槽一下,Navicat逆向的图没PowerDesigner好看)

技术方案:

使用工具:Navicat

        Navicat是国内的一款数据库客户端,内置有模型功能,可以实现需求中,选中一个模块的所有表,逆向表到模型,从而生成ER图,但如果选中表中,没有外键关联,生成出来的模型,并没有像需求中那样,有直观的线连接,所以需要给对应表生成外键SQL。

        从Navicat中选中所有表导出为SQL时发现下图规律

解决方案:

1. 把每个表语句拆分出来

2. 主表与关联表,主表不需要生产外键,关联表可以通过小撇号判断是否需要外键

3. 说再多文字不如读一遍代码更清晰

package com.example.demo; import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.nio.file.Files;import java.nio.file.Paths;import java.util.ArrayList;import java.util.Arrays;import java.util.HashMap;import java.util.List;import java.util.Map;import java.util.Set;import java.util.stream.Collectors; public class MysqlERGenerate {    public static void main(String[] args) throws IOException {        StringBuilder builder = new StringBuilder();        // 输入从Navicat导出的表结构sql文件 将文件读取出来 放入字符串中        InputStream is = Files.newInputStream(Paths.get("C:\\Users\\admin\\Desktop\\ddl.sql"));        String line;        BufferedReader reader = new BufferedReader(new InputStreamReader(is));        line = reader.readLine();        while (line != null) {            builder.append(line);            builder.append("\n");            line = reader.readLine();        }        reader.close();        is.close();        String sql = builder.toString();         // 按照规律 使用CREATE TABLE进行分割 并删掉一个文件注释部分        String[] split = sql.split("CREATE TABLE");        List list = new ArrayList<>(Arrays.asList(split));        list.remove(0);        // 使用开头两个小撇号进行截取 得到表名 转为Map<表名, SQL>        Map collect = list.stream().collect(Collectors.toMap(k -> {            int firstIndex = k.indexOf("`");            return k.substring(++firstIndex, k.indexOf("`", firstIndex));        }, v -> v));         // 需要创建外键的字段与对应的主表名称 Map<外键名, 外键主表名>        Map foreignKey = new HashMap<>();        foreignKey.put("ticket_no", "ticket");        foreignKey.put("ticket_define_no", "ticket_define");        foreignKey.put("pro_no", "pro_main");        // 循环判断,生成外键SQL        Set foreignKeyFields = foreignKey.keySet();        for (String mainTableName : collect.keySet()) {            String val = collect.get(mainTableName);            for (String field : foreignKeyFields) {                if (!mainTableName.equals(foreignKey.get(field)) && val.indexOf("`" + field + "`") > 0) {                    String createForeignKeySql = String.format("alter table %s add foreign key %s(%s) references %s(%s);", mainTableName, mainTableName + field + System.currentTimeMillis(), field, foreignKey.get(field), field);                    System.out.println(createForeignKeySql);                }            }        }    }}
登录后复制

运行效果:只复制出部分,实际远比这个多

alter table pro_param add foreign key pro_parampro_no1650765563395(pro_no) references pro_main(pro_no);alter table pro_shop_priority_his_20200805 add foreign key pro_shop_priority_his_20200805pro_no1650765563423(pro_no) references pro_main(pro_no); alter table ticket_define_shop add foreign key ticket_define_shopticket_define_no1650765563423(ticket_define_no) references ticket_define(ticket_define_no);alter table ticket_define_item add foreign key ticket_define_itemticket_define_no1650765563425(ticket_define_no) references ticket_define(ticket_define_no); alter table ticket_his_2019 add foreign key ticket_his_2019ticket_no1650765563432(ticket_no) references ticket(ticket_no);alter table ticket_his_2018 add foreign key ticket_his_2018ticket_no1650765563433(ticket_no) references ticket(ticket_no);
登录后复制

外键语句不要去开发测试生产等环境执行,要自己在本地新建库

新建库时,只转结构就好,不然数据多了,外键语句执行特慢

结束后,想要那些表之间的关系图,只需要选中后逆向表到模型即可得到需求中的效果

如果资金充裕,可以打赏请我喝杯咖啡,谢谢 Thanks♪(・ω・)ノ

以上就是如何快速生成MySQL数据库关系图的详细内容,更多请关注易企推科技其它相关文章!


本文地址:网络百科频道 https://www.eeeoo.cn/wangluo/1151138.html,嗨游网一个专业手游免费下载攻略知识分享平台,本站部分内容来自网络分享,不对内容负责,如有涉及到您的权益,请联系我们删除,谢谢!


网络百科
小编:小嗨整编
相关文章相关阅读
  • 电脑如何设置密码锁屏(电脑如何设置密码的方法)?

    电脑如何设置密码锁屏(电脑如何设置密码的方法)?

    电脑如何设置密码锁屏(电脑如何设置密码的方法)?随着电脑在日常生活中的普及,个人信息的安全性越来越受到重视。设置密码锁屏是保护电脑隐私的有效方法。本文将为您详细介绍如何在电脑上设置密码锁屏,帮助您轻松实现电脑安全防护。一、Windows系统...

  • 360皮肤中心如何关闭(360皮肤中心怎样删除)?

    360皮肤中心如何关闭(360皮肤中心怎样删除)?

    360皮肤中心如何关闭(360皮肤中心怎样删除)?360皮肤中心是360公司推出的一款电脑软件,用户可以通过它来更改电脑桌面图标、界面风格等,从而实现个性化设置。然而,有些用户可能觉得360皮肤中心的使用体验不佳,想要关闭或删除它。360皮...

  • dnf升级攻略1到100详细(dnf升级怎么快速升级)?

    dnf升级攻略1到100详细(dnf升级怎么快速升级)?

    dnf升级攻略1到100详细(dnf升级怎么快速升级)?以下是一份dnf从1级到100级的详细升级攻略,帮助您快速升级:dnf升级攻略1到100详细1.1-10级:跟随主线任务,这是最快速的方式。完成每日的推荐任务,这些通常会给较多的经验。...

  • 王者荣耀游戏视频怎么生成(王者荣耀游戏视频是自动生成的吗)?

    王者荣耀游戏视频怎么生成(王者荣耀游戏视频是自动生成的吗)?

    王者荣耀游戏视频怎么生成(王者荣耀游戏视频是自动生成的吗)?王者荣耀作为一款广受欢迎的多人在线战斗竞技游戏,其中的精彩瞬间总是让人想要记录下来。王者荣耀提供了自动生成游戏视频的功能,让玩家在享受游戏的同时,也能轻松记录下自己的高光时刻。王者...

  • 魔兽世界快速升级攻略(魔兽世界快速升级路线)

    魔兽世界快速升级攻略(魔兽世界快速升级路线)

    魔兽世界快速升级攻略(魔兽世界快速升级路线)在魔兽世界中,快速升级是许多玩家追求的目标。合理的升级路线和高效的方法可以让玩家更快地达到满级,开启更多精彩内容。下面,我将为大家介绍一份魔兽世界快速升级攻略,帮助大家打造一条高效的升级路线。一、...

  • sql教程快速入门(sql零基础入门教程)

    sql教程快速入门(sql零基础入门教程)

    sql教程快速入门(sql零基础入门教程)sql是一种用于管理和处理关系型数据库的编程语言。它主要用于查询、更新、删除和管理数据库中的数据。SQL是关系型数据库操作的标准语言,被广泛应用于各种数据库系统中,如MySQL、Oracle、SQL...

  • 密码本忘记密码怎么开锁(密码本忘记密码如何打开)?

    密码本忘记密码怎么开锁(密码本忘记密码如何打开)?

    密码本忘记密码怎么开锁(密码本忘记密码如何打开)?随着信息安全意识的提高,越来越多的人开始使用密码本来记录重要的账号和密码。然而,忘记密码本密码的情况也时有发生。本文将为您介绍几种忘记密码本密码时的开锁方法。密码本忘记密码怎么开锁1.按照提...

  • cad迷你看图软件如何打印图纸(cad迷你看图软件下载官网)?

    cad迷你看图软件如何打印图纸(cad迷你看图软件下载官网)?

    cad迷你看图软件如何打印图纸(cad迷你看图软件下载官网)?AutoCAD(AutoComputerAidedDesign)是美国Autodesk公司首次于1982年生产的自动计算机辅助设计软件,用于二维绘图、详细绘制、设计文档和基本三维...

  • 周排行
  • 月排行
  • 年排行

精彩推荐