java一键生成数据库说明文档html格式

要验收项目了,要写数据库文档,一大堆表太费劲了,直接生成一个吧,本来想用个别人的轮子,网上看了几个,感觉效果不怎么好,自己动手写一个吧。抽空再把字典表补充进去就OK了

先看效果:

目录快速导航

生成效果

关键代码

复制代码
 try {
            	String prefixTables = "sys_monitor_db_handle.selectDbTabUsedInfo";
   		        String prefixStructure = "sys_monitor_db_handle.selectDbClumInfo";
                String dbname="dbname";
   		        // 获取所有表名
   		        Map<String, Object> paramTables = new HashMap<>();
   		        paramTables.put("tableen", dbname);
   		        String sqlTables = SqlManage.getInstance().getSqlByid(paramTables, prefixTables);
   		        List<Map<String, Object>> tablesList = BaseDao.queryList(sqlTables);

   		        // 生成HTML文档
   		        StringBuilder htmlBuilder = new StringBuilder();
   		        String name="数据库说明文档";
				String level="2.0";
				String auth="wheart.cn";
				String date=ToolDateTime.getYYYYmmdd();
				generateHtmlHeader(htmlBuilder,name,level,auth,date);
				
				 StringBuilder navBuilder = new StringBuilder();
				 navBuilder.append("<nav><h2 id='mulu'>目录</h2><ul>\n");
   		        for (Map<String, Object> tableInfo : tablesList) {
   		            String tableName = (String) tableInfo.get("tableen");
   		            String tableNamecn = tableInfo.get("tabcn")+"";
   		            generateHtmlnav(navBuilder,tableName,tableNamecn);
   		            Map<String, Object> paramStructure = new HashMap<>();
   		            paramStructure.put("tableen", tableName);
   		            paramStructure.put("dbname", dbname);
   		            String sqlStructure = SqlManage.getInstance().getSqlByid(paramStructure, prefixStructure);
   		            List<Map<String, Object>> columnsList = BaseDao.queryList(sqlStructure);
   		            generateHtmlTable(htmlBuilder, tableName, tableNamecn, columnsList);
   		        }
   		       navBuilder.append("</ul></nav>\n"); // 结束导航列表和导航部分
   		       String conDivStart = "<div class=\"con\">";
   		      int conDivIndexStart = htmlBuilder.indexOf(conDivStart);
   		      htmlBuilder.insert(conDivIndexStart + conDivStart.length(), navBuilder.toString());
   		        generateHtmlFooter(htmlBuilder);
   		        
   		     writeHtmlToFile(htmlBuilder.toString(), name+"_"+auth+"_"+level+"_"+date+".html");
相关推荐
玄斎23 分钟前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
李慕婉学姐26 分钟前
【开题答辩过程】以《基于Android的出租车运行监测系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·后端·vue
m0_7400437334 分钟前
SpringBoot05-配置文件-热加载/日志框架slf4j/接口文档工具Swagger/Knife4j
java·spring boot·后端·log4j
编织幻境的妖35 分钟前
SQL查询连续登录用户方法详解
java·数据库·sql
编程小Y1 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
未若君雅裁1 小时前
JVM面试篇总结
java·jvm·面试
kk哥88991 小时前
C++ 对象 核心介绍
java·jvm·c++
招风的黑耳2 小时前
我用SpringBoot撸了一个智慧水务监控平台
java·spring boot·后端
xunyan62342 小时前
面向对象(下)-接口的理解
java·开发语言
零度@2 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql