MybatisPlus代码生成器

本文介绍如何使用MyBatisPlus代码生成器快速搭建项目骨架,包括配置依赖、生成实体类、Mapper、Service及Controller等,并展示了具体步骤与注意事项。

引言:

学习了MybatisPlus的代码生成器,做一些相关笔记

Spirngboot版本:2.6.1

MybatisPlus版本:3.4.3.4

Maven版本:3.6.1

jdk:1.8

需要引入相关依赖:

         <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.3.4</version>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.4.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.2</version>
        </dependency>

创建一个类:MyBatisPlusAuto

一些注意点:

1. 相关包配置:mybatisplus默认会创建出controller,service接口及其实现类,mapper接口和实体类,可自己定义相关类的名称,以自己定义的优先

2. 配置模板引擎:最好配置一下

       // 配置模板,如果没有这一步的话mybatisplus会在mapper层上同时创建出xml包及其xml文件
        TemplateConfig templateConfig = new TemplateConfig();

        templateConfig.setXml(null);
        mpg.setTemplate(templateConfig);
public class MyBatisPlusAuto {

    public static String scanner(String tip) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入" + tip + ":");
        if (scanner.hasNext()) {
            String ipt = scanner.next();
            if (StringUtils.isNotBlank(ipt)) {
                return ipt;
            }
        }
        throw new MybatisPlusException("请输入正确的" + tip + "!");
    }

    public static void main(String[] args) {
        AutoGenerator mpg = new AutoGenerator();

        //全局配置
        GlobalConfig globalConfig = new GlobalConfig();
        String property = System.getProperty("user.dir");
        globalConfig.setOutputDir(property + "/src/main/java");
        globalConfig.setAuthor("你的作者名");
        globalConfig.setOpen(false);
        globalConfig.setFileOverride(false);
        globalConfig.setServiceName("%sService");
        globalConfig.setDateType(DateType.ONLY_DATE);
        mpg.setGlobalConfig(globalConfig);

        //数据源配置
        DataSourceConfig dataSourceConfig = new DataSourceConfig();
        /*
            mysql8.0以上版本需要在数据库名后面加上?serverTimezone=UTC
            mysql8.0以上版本为:com.mysql.cj.jdbc.Driver
                     以下版本为:com.mysql.jdbc.Driver
        */
        dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/你的数据库名");

        dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver");
        dataSourceConfig.setPassword("数据库密码");
        dataSourceConfig.setUsername("root");
        mpg.setDataSource(dataSourceConfig);

        /*
        相关包配置
        */                                           
        PackageConfig packageConfig = new PackageConfig();
        //packageConfig.setModuleName(scanner("模块名"));//模块名,可有可无
        packageConfig.setParent("com.xxx.www");
        packageConfig.setEntity("pojo");

         //mybatisPlus会自动创建
//        packageConfig.setMapper("mapper");
//        packageConfig.setService("service");
//        packageConfig.setController("controller");
        mpg.setPackageInfo(packageConfig);

        // 自定义配置
        InjectionConfig cfg = new InjectionConfig() {
            @Override
            public void initMap() {
                // to do nothing
            }
        };

        String templatePath = "/templates/mapper.xml.vm";
        // 自定义输出配置
        List<FileOutConfig> focList = new ArrayList<>();
        // 自定义配置会被优先输出
        focList.add(new FileOutConfig(templatePath) {
            @Override
            public String outputFile(TableInfo tableInfo) {
                // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!
                return property + "/src/main/resources/mapper/" + packageConfig.getModuleName()
                        + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
            }
        });

        cfg.setFileOutConfigList(focList);
        mpg.setCfg(cfg);

        // 配置模板,如果没有这一步的话mybatisplus会在mapper层上同时创建出xml包及其xml文件
        TemplateConfig templateConfig = new TemplateConfig();

        // 配置自定义输出模板
        //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
        // templateConfig.setEntity("templates/entity2.java");
        // templateConfig.setService();
        // templateConfig.setController();

        templateConfig.setXml(null);
        mpg.setTemplate(templateConfig);

        //相关策略配置
        StrategyConfig strategyConfig = new StrategyConfig();
        strategyConfig.setNaming(NamingStrategy.underline_to_camel);
        strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
        strategyConfig.setInclude(scanner("表名,多个英文逗号分割").split(","));
        strategyConfig.setEntityLombokModel(true);//自动lombok
        //逻辑删除
        //strategyConfig.setLogicDeleteFieldName("deleted");
        //自动填充
        TableFill createFill = new TableFill("gmt_create", FieldFill.INSERT);
        TableFill modifiedFill = new TableFill("gmt_modified",FieldFill.INSERT_UPDATE);
        List<TableFill> tableFills = new ArrayList<>();
        tableFills.add(createFill);
        tableFills.add(modifiedFill);
        strategyConfig.setTableFillList(tableFills);
        //乐观锁
       // strategyConfig.setVersionFieldName("version");
        strategyConfig.setRestControllerStyle(true);
        strategyConfig.setControllerMappingHyphenStyle(true);
        mpg.setStrategy(strategyConfig);
        mpg.execute();
    }
}

最后进行测试即可:

目录结构:

输入要生成的表名:

生成完毕(能看到对应的包及xml文件都创建出来了):

 

最后只需要关注业务开发就行啦!!

### MyBatisPlus 代码生成器使用教程 #### 导入依赖 为了能够顺利运行MyBatisPlus代码生成器,在项目中需引入必要的Maven依赖。这些依赖项包含了MyBatisPlus的核心库以及代码生成所需的组件。 ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> <!-- 代码生成器 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.4.0</version> </dependency> <!-- 模板引擎 freemarker 或 velocity 可选 --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.31</version> </dependency> ``` #### application.yaml 配置及对应配置类 在`application.yaml`文件内设置数据库连接参数,以便于后续操作可以访问到目标数据源。同时创建对应的Java Bean来加载此配置信息[^1]。 ```yaml spring: datasource: url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver ``` 对于上述YAML中的属性映射至实体对象: ```java @ConfigurationProperties(prefix = "spring.datasource") public class DataSourceConfig { private String url; private String username; private String password; private String driverClassName; // getter and setter methods... } ``` #### 工具类封装 定义一个静态工具类用于初始化并启动代码生成功能。此类内部会构建AutoGenerator实例,并通过链式调用来指定模板路径、包名结构以及其他必要选项。 ```java 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.NamingStrategy; public class CodeGenerator { public static void main(String[] args) { AutoGenerator mpg = new AutoGenerator(); // 设置全局配置 GlobalConfig gc = new GlobalConfig(); gc.setOutputDir(System.getProperty("user.dir") + "/src/main/java"); gc.setAuthor("Your Name"); gc.setOpen(false); mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("password"); mpg.setDataSource(dsc); // 包的信息 PackageConfig pc = new PackageConfig(); pc.setParent("com.example.demo"); pc.setModuleName(null); // 不开启模块化多包模式 mpg.setPackageInfo(pc); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.underline_to_camel); strategy.setEntityLombokModel(true); strategy.setRestControllerStyle(true); mpg.setStrategy(strategy); // 执行生成 mpg.execute(); } } ``` #### 测试代码生成 完成以上准备工作之后,只需简单地编译并运行该程序即可触发自动化的CRUD接口及相关模型类的生产过程。这一步骤通常是在开发环境中进行验证性的尝试,确保一切按预期工作正常。 #### 测试执行 MyBatisPlus 是否可行 一旦自动生成完毕,则可以在实际业务逻辑里边集成新产生的DAO层接口与Service实现类来进行功能测试。此时应该关注点在于确认基本的数据持久化操作能否顺利完成,比如新增记录、查询列表等基础动作是否符合设计初衷。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值