位置放在此处,直接运行即可

一、pom依赖

        <!--mybatis-plus -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>

二、源码

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.jupiter.api.Test;

/**
 * 一键生成 controller serviceImpl  service  pojo文件
 */
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("D:\\自己的项目路径" + "/src/main/java");

        //============================== 【 1、生成文件的作者名称 】 =============================================
        //作者
        gc.setAuthor("自己的名字");
        //生成后是否打开资源管理器
        gc.setOpen(true);
        //重新生成文件是否覆盖
        gc.setFileOverride(false);

        //去掉Service接口的首字母I
        gc.setServiceName("%sService");

        //主键策略
        gc.setIdType(IdType.AUTO);
        //定义生成的实体类中的日期类型
        gc.setDateType(DateType.ONLY_DATE);
        //开启Swagger2
        gc.setSwagger2(true);

        mpg.setGlobalConfig(gc);

        //3.数据库源配置
        DataSourceConfig dsc = new DataSourceConfig();
        //============================== 【 2、修改你自己的数据库连接信息 】 =============================================
        dsc.setUrl("jdbc:mysql://数据库ip地址:3306/数据库名?serverTimezone=GMT%2b8");
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        //数据库账号和密码
        dsc.setUsername("root");
        dsc.setPassword("root");
        dsc.setDbType(DbType.MYSQL);
        mpg.setDataSource(dsc);


        //4.包配置
        PackageConfig pc = new PackageConfig();
        //============================== 【 3、修改你自己要生成的模块名以及包名 】 =============================================
        //模块名
        pc.setModuleName("自己的项目名");
        //包开头 com.test
        pc.setParent("com.自己的包名");

        //要生成的包名 com.自己的包名.自己的项目名.controller依次类推,无需改动
        //com.test.myProject
        pc.setController("controller");
        //com.test.pojo
        pc.setEntity("pojo");
        //这里生成两个
        //com.test.service
        //com.test.service.serviceImpl
        pc.setService("service");
        //com.test.mapper
        pc.setMapper("mapper");
        mpg.setPackageInfo(pc);

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

        //============================== 【 4、修改你自己要生成的数据表 】 =============================================
        //数据表名,多个表用逗号分割
        strategy.setInclude("数据表1","数据表2","数据表3");

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

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

        //restful opi风格控制器
        strategy.setRestControllerStyle(true);
        //urlz中驼峰命名法
        strategy.setControllerMappingHyphenStyle(true);

        mpg.setStrategy(strategy);

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

    }
}

三、运行+效果

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐