MybatisPlus代码生成器 快速上手

作用

  • 构建controller service entity mapper

使用

  • 依赖
<!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 -->
<dependency>
	<groupId>org.apache.velocity</groupId>
	<artifactId>velocity-engine-core</artifactId>
</dependency>
  • 直接在测试执行固定代码 复制到项目的test目录下执行就行
public class CodeGenerator {

    @Test
    public void run() {

        // 1、创建代码生成器
        AutoGenerator mpg = new AutoGenerator();

        // 2、全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");   //得到 路径  写在下面  目前没用 下面直接写了绝对路径了 
         //gc.setOutputDir(projectPath + "/src/main/java");  //亲测这也OK
        gc.setOutputDir("D:\\maven\\guli_parent\\service\\service_edu" + "/src/main/java");//输出目录  你项目的Java目录下  使用绝对路径      这个换项目要改一下

        gc.setAuthor("testjava");   //生成的作者名
        gc.setOpen(false); //生成后是否打开资源管理器    不需要改动
        gc.setFileOverride(false); //重新生成时文件是否覆盖   不需要改动

        //UserServie
        gc.setServiceName("%sService");	//去掉Service接口的首字母I  不需要改动

        gc.setIdType(IdType.ID_WORKER_STR); //主键策略   这个看你的策略是啥 这里id是str
        gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
        gc.setSwagger2(true);//开启Swagger2模式   

        mpg.setGlobalConfig(gc);

        // 3、数据源配置   根据自己的配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8");
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("333");
        dsc.setDbType(DbType.MYSQL);
        mpg.setDataSource(dsc);

        // 4、包配置
        PackageConfig pc = new PackageConfig();
       
        
        pc.setParent("com.atguigu");//生成的包名
         pc.setModuleName("eduservice"); //生成的模块名
        //包  com.atguigu.eduservice
        pc.setController("controller");
         //包  com.atguigu.eduservice.controller
        pc.setEntity("entity");
        pc.setService("service");
        pc.setMapper("mapper");
        mpg.setPackageInfo(pc);

        // 5、策略配置
        StrategyConfig strategy = new StrategyConfig();

        strategy.setInclude("edu_teacher");   //对应的表名  多张表 用逗号连接起来  根据该表生成对应的实体类 EduTeacher

        strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
        strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀   

        strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
        strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作

        strategy.setRestControllerStyle(true); //restful api风格控制器
        strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符

        mpg.setStrategy(strategy);


        // 6、执行
        mpg.execute();
    }
}


  • 需要改的

       gc.setOutputDir("D:\\maven\\guli_parent\\service\\service_edu" + "/src/main/java");//输出目录  你项目的	Java目录下  使用绝对路径      这个换项目要改一下
       gc.setIdType(IdType.ID_WORKER_STR); //主键策略   这个看你的策略是啥 我这里id是str
     
     	数据库改为你的数据库
         
         表名称也需要改
    

生成的效果图 部分

image-20210712183040099


版权声明:本文为qq_45834768原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。