mybatis-plus自动生成模板

2023-12-05

1.依赖pom

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.5.4</version>
</dependency>
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.4</version>
</dependency>
<dependency>
    <groupId>org.freemarker</groupId>
    <artifactId>freemarker</artifactId>
    <version>2.3.32</version>
</dependency>
<dependency>
    <groupId>com.mysql</groupId>
    <artifactId>mysql-connector-j</artifactId>
    <scope>runtime</scope>
</dependency>
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>

2.生成代码

   String url = "jdbc:mysql://xx:3306/xx?serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8&useSSL=false";

FastAutoGenerator.create(url, "username", "passsword")
	.globalConfig(builder -> {
	    builder.author("fuhao") // 设置作者
	            .enableSwagger() // 开启 swagger 模式
	            .fileOverride() // 覆盖已生成文件
	            .outputDir("D://workspace/xx/src/main/java"); // 指定输出目录
	})
	.dataSourceConfig(builder -> builder.typeConvertHandler((globalConfig, typeRegistry, metaInfo) -> {
	    int typeCode = metaInfo.getJdbcType().TYPE_CODE;
	    if (typeCode == Types.SMALLINT) {
	        // 自定义类型转换
	        return DbColumnType.INTEGER;
	    }
	    return typeRegistry.getColumnType(metaInfo);
	
	}))
	.packageConfig(builder -> {
	    builder.parent("com.xx.xx")
	            .entity("entity")
	            .service("service")
	            .serviceImpl("service.impl")
	            .mapper("mapper")
	            .xml("mapper.xml")
	            .controller("controller")
	            .pathInfo(Collections.singletonMap(OutputFile.xml, "D://workspace/xx/src/main/resources/mapper")) //mapper.xml生成路径设置
	            ;
	})
	.strategyConfig(builder -> {
	    builder
	            .addInclude("xx") // 指定要生成的表,不定项参数,可指定多个
	            .likeTable(new LikeTable("xx_"))//模糊匹配要生成的表
	            .addTablePrefix("xx_")  //生成类、mapper时,忽略、删除的前缀
	            .addFieldPrefix("xx") //生成类字段时,忽略、删除的前缀
	            .addFieldSuffix("")  //生成类字段时,忽略、删除的后缀
	    ; // 设置过滤表前缀
	})
	.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
	.execute();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

mybatis-plus自动生成模板 的相关文章

  • MySql常用面试题

    1 MySql Oracle Sql Service 的区别 Sql Service 只能在 Windows 上使用 而 MySql 和 Oracle 可以在其他系统上使用 而且可以支持数 据库不同系统之间的移植 MySql 开源免费的 S

随机推荐