当前位置: 首页 > article >正文

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");

http://www.kler.cn/a/282651.html

相关文章:

  • git常用命令+搭vscode使用
  • git使用及上线流程(仅为我工作中常用)
  • gitHub常用操作
  • 创建vue插件,发布npm
  • 操作系统实验:在linux下用c语言模拟进程调度算法程序
  • git命令提交项目
  • 多项目同时进行:如何做好进度管理
  • 阿里龙晰系统上将yum安装的myql_8.0.36升级到mysql_8.4.0的过程
  • Ubuntu下修改Ollama的模型存储路径
  • Qt与SVG
  • Vue3-win7搭建vue3环境
  • FGF23:家族靶向治疗先行者
  • 【Rust光年纪】保护用户数据安全隐私:探秘Rust机密计算与安全库
  • Ubuntu24.04 安装向日葵远程访问工具
  • nginx部署前端vue项目
  • LaViT:Less-Attention Vision Transformer的特性与优点
  • 【Python机器学习】NLP分词——利用分词器构建词汇表(五)——将词汇表扩展到n-gram
  • Linux操作系统su命令详解,附代码
  • 牛客小白月赛99 F-自爆机器人
  • Java 集合Collection(List、Set)Map
  • 高级java每日一道面试题-2024年8月28日-基础篇-ArrayList的底层工作原理?
  • SELF-INSTRUCT: Aligning Language Modelswith Self-Generated Instructions 学习
  • vscode添加到环境变量之快捷使用
  • Typora + PicGo + Gitee 实现图片自动上传
  • Qt调用外部exe并嵌入到Qt界面中(验证成功的成功)
  • linux 创建文件节点