mybatisplus代码生成器

本文介绍如何使用MyBatis Plus代码生成器快速生成包括Service接口、ServiceImpl类及Mapper接口等在内的基础代码,通过具体示例展示了依赖引入、代码生成配置与执行过程。

提示:个人学习笔记

1、引入依赖

在pom.xml中引入如下依赖:

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.5.1</version>
        </dependency>
        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.31</version>
        </dependency>

2、生成代码

  运行该生成代码即可

public class generatorTest {
    public static void main(String[] args) {
        FastAutoGenerator.create("jdbc:mysql://127.0.0.1:3306/mybatis_plus? characterEncoding=utf-8&userSSL=false", "root", "root").globalConfig(builder -> {
                    builder.author("***") // 设置作者
                            .fileOverride() // 覆盖已生成文件
                            .outputDir("D://mybatis_plus"); // 指定输出目录
                }).packageConfig(builder -> {
                    builder.parent("com") // 设置父包名
                            .moduleName("mybatisplus") // 设置父包模块名
                            .pathInfo(Collections.singletonMap(OutputFile.mapperXml, "D://mybatis_plus")); // 设置mapperXml生成路径
                }).strategyConfig(builder -> {
                    builder.addInclude("t_user") // 设置需要生成的表名
                            .addInclude("t_product")
                            .addTablePrefix("t_"); // 设置过滤表前缀
                }).templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker 引擎模板,默认的是Velocity引擎模板
                .execute();
    }
}

3、效果图

  • service接口了继承IService<T>(T即操作的实体)
  • serviceImpl类实现了service接口并且实现了IService<T>的实现类ServiceImpl<R,T>
  • mapper接口继承了BaseMapper<T>
  • mapper.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实现类来进行功能测试。此时应该关注点在于确认基本的数据持久化操作能否顺利完成,比如新增记录、查询列表等基础动作是否符合设计初衷。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值