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");
相关推荐
q***649714 小时前
VS与SQL Sever(C语言操作数据库)
c语言·数据库·sql
程序员小假14 小时前
有了解过 SpringBoot 的参数配置吗?
java·后端
f***241114 小时前
java学习进阶之路,如果从一个菜鸟进阶成大神
java·开发语言·学习
ALex_zry14 小时前
高并发系统渐进式改造技术调研报告:策略、架构与实战
java·运维·架构
SimonKing14 小时前
等保那些事
java·后端·程序员
无敌最俊朗@14 小时前
Qt面试题day01
java·数据库·面试
AH_HH15 小时前
Spring Boot 4.0 发布总结:新特性、依赖变更与升级指南
java·spring boot·后端
mqiqe15 小时前
【Spring AI MCP】六、SpringAI MCP 服务端 STDIO & SSE
java·人工智能·spring
Tadas-Gao15 小时前
Spring Boot 4.0架构革新:构建更精简、更安全、更高效的Java应用
java·spring boot·分布式·微服务·云原生·架构·系统架构
小小测试开发15 小时前
JMeter XPath提取器用法详解:XML/HTML响应数据提取神器
xml·jmeter·html