数据库设计文档生成工具类
在企业级开发中、我们经常会有编写数据库表结构文档的时间付出,如果数据库表结构更新了还得手动更新维护到文档中,很是繁琐。GitHub 上发现了一个好工具 screw(螺丝钉),在此分享下1、引入依赖cn.smallbun.screwscrew-core1.0.5com.zaxxerHikariCP3.4.5mysqlmysql-connector-java8.0.20runtime
在企业级开发中、我们经常会有编写数据库表结构文档的时间付出,如果数据库表结构更新了还得手动更新维护到文档中,很是繁琐。GitHub 上发现了一个好工具 screw(螺丝钉),在此分享下
-
1、引入依赖
cn.smallbun.screw screw-core 1.0.5 com.zaxxer HikariCP 3.4.5 mysql mysql-connector-java 8.0.20 runtime
核心 cn.smallbun.screw
-
2、生成工具类
import cn.smallbun.screw.core.Configuration;
import cn.smallbun.screw.core.engine.EngineConfig;
import cn.smallbun.screw.core.engine.EngineFileType;
import cn.smallbun.screw.core.engine.EngineTemplateType;
import cn.smallbun.screw.core.execute.DocumentationExecute;
import cn.smallbun.screw.core.process.ProcessConfig;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;import javax.sql.DataSource;
import java.util.ArrayList;/**
- 数据库设计文档生成类
/
public class BuildDatabaseDoc {
/*-
文档生成
*/
public static void main(String[] args) {
// 数据源
HikariConfig hikariConfig = new HikariConfig();
// 数据库连接信息
hikariConfig.setDriverClassName(“com.mysql.cj.jdbc.Driver”);
hikariConfig.setJdbcUrl(“jdbc:mysql://localhost:3306/walking?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC”);
hikariConfig.setUsername(“root”);
hikariConfig.setPassword(“123456”);
// 设置可以获取tables remarks信息
hikariConfig.addDataSourceProperty(“useInformationSchema”, “true”);
hikariConfig.setMinimumIdle(2);
hikariConfig.setMaximumPoolSize(5);
DataSource dataSource = new HikariDataSource(hikariConfig);
// 生成配置
EngineConfig engineConfig = EngineConfig.builder()
// 生成文件路径
.fileOutputDir(“E:/”)
// 打开目录
.openOutputDir(true)
// 文件类型
.fileType(EngineFileType.HTML)
// 生成模板实现
.produceType(EngineTemplateType.freemarker)
// 自定义文件名称
.fileName(“数据库设计文档”).build();// 忽略表
ArrayList ignoreTableName = new ArrayList<>();
ignoreTableName.add(“test_user”);
ignoreTableName.add(“test_group”);
// 忽略表前缀
ArrayList ignorePrefix = new ArrayList<>();
ignorePrefix.add(“test_”);
// 忽略表后缀
ArrayList ignoreSuffix = new ArrayList<>();
ignoreSuffix.add("_test");
ProcessConfig processConfig = ProcessConfig.builder()
// 指定生成逻辑、当存在指定表、指定表前缀、指定表后缀时,将生成指定表,其余表不生成、并跳过忽略表配置
// 根据名称指定表生成
.designatedTableName(new ArrayList<>())
// 根据表前缀生成
.designatedTablePrefix(new ArrayList<>())
// 根据表后缀生成
.designatedTableSuffix(new ArrayList<>())
// 忽略表名
.ignoreTableName(ignoreTableName)
// 忽略表前缀
.ignoreTablePrefix(ignorePrefix)
// 忽略表后缀
.ignoreTableSuffix(ignoreSuffix).build();
// 配置
Configuration config = Configuration.builder()
// 版本
.version(“1.0.0”)
// 描述
.description(“数据库设计文档”)
// 数据源
.dataSource(dataSource)
// 生成配置
.engineConfig(engineConfig)
// 生成配置
.produceConfig(processConfig)
.build();
// 执行生成
new DocumentationExecute(config).execute();
}
}
-
- 数据库设计文档生成类
-
3、效果图预览
如您在阅读中发现不足,欢迎留言!!!
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)