|
| 1 | +import cn.smallbun.screw.core.Configuration; |
| 2 | +import cn.smallbun.screw.core.engine.EngineConfig; |
| 3 | +import cn.smallbun.screw.core.engine.EngineFileType; |
| 4 | +import cn.smallbun.screw.core.engine.EngineTemplateType; |
| 5 | +import cn.smallbun.screw.core.execute.DocumentationExecute; |
| 6 | +import cn.smallbun.screw.core.process.ProcessConfig; |
| 7 | +import com.zaxxer.hikari.HikariConfig; |
| 8 | +import com.zaxxer.hikari.HikariDataSource; |
| 9 | + |
| 10 | +import javax.sql.DataSource; |
| 11 | +import java.util.Arrays; |
| 12 | +import java.util.Collections; |
| 13 | + |
| 14 | +public class ScrewMain { |
| 15 | + |
| 16 | + private static final String DB_URL = "jdbc:mysql://400-infra.server.iocoder.cn:3306"; |
| 17 | + private static final String DB_NAME = "mall_system"; |
| 18 | + private static final String DB_USERNAME = "root"; |
| 19 | + private static final String DB_PASSWORD = "3WLiVUBEwTbvAfsh"; |
| 20 | + |
| 21 | + private static final String FILE_OUTPUT_DIR = "/Users/yunai/screw_test"; |
| 22 | + private static final EngineFileType FILE_OUTPUT_TYPE = EngineFileType.HTML; // 可以设置 WORD 或者 Markdown 格式 |
| 23 | + private static final String DOC_FILE_NAME = "数据库文档"; |
| 24 | + private static final String DOC_VERSION = "1.0.0"; |
| 25 | + private static final String DOC_DESCRIPTION = "文档描述"; |
| 26 | + |
| 27 | + public static void main(String[] args) { |
| 28 | + // 创建 screw 的配置 |
| 29 | + Configuration config = Configuration.builder() |
| 30 | + .version(DOC_VERSION) // 版本 |
| 31 | + .description(DOC_DESCRIPTION) // 描述 |
| 32 | + .dataSource(buildDataSource()) // 数据源 |
| 33 | + .engineConfig(buildEngineConfig()) // 引擎配置 |
| 34 | + .produceConfig(buildProcessConfig()) // 处理配置 |
| 35 | + .build(); |
| 36 | + |
| 37 | + // 执行 screw,生成数据库文档 |
| 38 | + new DocumentationExecute(config).execute(); |
| 39 | + } |
| 40 | + |
| 41 | + /** |
| 42 | + * 创建数据源 |
| 43 | + */ |
| 44 | + private static DataSource buildDataSource() { |
| 45 | + // 创建 HikariConfig 配置类 |
| 46 | + HikariConfig hikariConfig = new HikariConfig(); |
| 47 | + hikariConfig.setDriverClassName("com.mysql.cj.jdbc.Driver"); |
| 48 | + hikariConfig.setJdbcUrl(DB_URL + "/" + DB_NAME); |
| 49 | + hikariConfig.setUsername(DB_USERNAME); |
| 50 | + hikariConfig.setPassword(DB_PASSWORD); |
| 51 | + hikariConfig.addDataSourceProperty("useInformationSchema", "true"); // 设置可以获取 tables remarks 信息 |
| 52 | + // 创建数据源 |
| 53 | + return new HikariDataSource(hikariConfig); |
| 54 | + } |
| 55 | + |
| 56 | + /** |
| 57 | + * 创建 screw 的引擎配置 |
| 58 | + */ |
| 59 | + private static EngineConfig buildEngineConfig() { |
| 60 | + return EngineConfig.builder() |
| 61 | + .fileOutputDir(FILE_OUTPUT_DIR) // 生成文件路径 |
| 62 | + .openOutputDir(false) // 打开目录 |
| 63 | + .fileType(FILE_OUTPUT_TYPE) // 文件类型 |
| 64 | + .produceType(EngineTemplateType.freemarker) // 文件类型 |
| 65 | + .fileName(DOC_FILE_NAME) // 自定义文件名称 |
| 66 | + .build(); |
| 67 | + } |
| 68 | + |
| 69 | + /** |
| 70 | + * 创建 screw 的处理配置,一般可忽略 |
| 71 | + * 指定生成逻辑、当存在指定表、指定表前缀、指定表后缀时,将生成指定表,其余表不生成、并跳过忽略表配置 |
| 72 | + */ |
| 73 | + private static ProcessConfig buildProcessConfig() { |
| 74 | + return ProcessConfig.builder() |
| 75 | + .designatedTableName(Collections.<String>emptyList()) // 根据名称指定表生成 |
| 76 | + .designatedTablePrefix(Collections.<String>emptyList()) //根据表前缀生成 |
| 77 | + .designatedTableSuffix(Collections.<String>emptyList()) // 根据表后缀生成 |
| 78 | + .ignoreTableName(Arrays.asList("test_user", "test_group")) // 忽略表名 |
| 79 | + .ignoreTablePrefix(Collections.singletonList("test_")) // 忽略表前缀 |
| 80 | + .ignoreTableSuffix(Collections.singletonList("_test")) // 忽略表后缀 |
| 81 | + .build(); |
| 82 | + } |
| 83 | + |
| 84 | +} |
0 commit comments