MybatisPlus代码生成器

本文介绍了如何使用MyBatis-Plus的3.4.0版本作为代码生成器,详细列出了所需的依赖、配置和代码段。通过配置数据源、Spring Boot应用设置、Config类以及Main方法,实现了数据库表到Java代码的自动生成,支持Lombok注解和逻辑删除。在实际操作中,用户需根据自身数据库信息进行相应修改。

这个版本的代码生成器我并未采用最新的3.5.1版本,而是旧版本 ,新版本代码生成器 可以直接去官网看文档即可

以下是代码生产所需的依赖、配置、代码段

、、、依赖、、

<!-- mybatis plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.0</version>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.4.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.3</version>
        </dependency>
    </dependencies>

新建项目的时候,我勾选了 web mysql 和 lombok 这三个

application.yml文件的配置

注意:这里,如果拿过去用的话 需要修改的地方只有一个 那就是 数据库的名称 我这里是 mybatis_plus 只需要修改为你的数据库文件即可

另外端口可以不设置也行吧  

上方我做了生产和测试的隔离但是我这里没有用到 也可以删除掉,看你个人的需要


spring:
  profiles:
    active: dev
  datasource:
    password: root
    username: root
    url: jdbc:mysql://localhost:3306/mybatis_plus?useSSL=flase&useUnicode=true&characterEncodeing=utf-8&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.cj.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource
#server port
server:
  port: 9000
#mybatisplus log
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    #luojishanchu
  global-config:
    db-config:
      logic-not-delete-value: 0
      logic-delete-value: 1


Config文件的配置

这些都是固定的写法 ,如果有自己需要的组件 也可以自己进行配置 Bean 即可

@MapperScan("com.yuan.Blog.mapper")
@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {
    @Bean
    public PaginationInnerInterceptor paginationInnerInterceptor(){
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
        return paginationInnerInterceptor;
    }


}

main.java

主文件的修改地方是数据源中数据库的名称,以及你的数据库用户名和密码 

另外如果你有多个数据库表需要生成,那么只需要在策略配置中 映射字段 添加进入即可 格式如下

strategyConfig.setInclude("user","priece"..........)


public class codeTest {
    public static void main(String[] args) {
        //构建代码生成器
        AutoGenerator mp = new AutoGenerator();

        //全局文件配置
        GlobalConfig globalConfig = new GlobalConfig();
        globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");
        globalConfig.setAuthor("yuan");
        globalConfig.setOpen(false);
        globalConfig.setServiceName("%sService"); //去前缀
        globalConfig.setIdType(IdType.ASSIGN_ID);
        globalConfig.setDateType(DateType.ONLY_DATE);
        mp.setGlobalConfig(globalConfig);
        //数据源配置
        DataSourceConfig dataSourceConfig = new DataSourceConfig();
        dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/mybatis_plus?useUnicode=true&useSSL=false&characterEncoding=utf8");
        dataSourceConfig.setDriverName("com.mysql.jdbc.Driver");
        dataSourceConfig.setUsername("root");
        dataSourceConfig.setPassword("root");
        mp.setDataSource(dataSourceConfig);
        //包配置
        PackageConfig packageConfig = new PackageConfig();
        packageConfig.setModuleName("Blog");
        packageConfig.setParent("com.yuan");
        packageConfig.setEntity("pojo");
        packageConfig.setController("controller");
        packageConfig.setMapper("mapper");
        packageConfig.setService("service");
        packageConfig.setServiceImpl("serviceimpl");
        mp.setPackageInfo(packageConfig);
        //策略配置
        StrategyConfig strategyConfig = new StrategyConfig();
        strategyConfig.setInclude("user");//设置要映射的表名字
        strategyConfig.setNaming(NamingStrategy.underline_to_camel);
        strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);
//        strategyConfig.setSuperEntityClass("你自己的父类实体,没有则不设置");
        strategyConfig.setEntityLombokModel(true);//自动lombok
//        strategyConfig.setRestControllerStyle(true);
        strategyConfig.setLogicDeleteFieldName("deleted");
        strategyConfig.setRestControllerStyle(true);//驼峰命名
        strategyConfig.setControllerMappingHyphenStyle(true);//url下划线
                //自动填充配置
        TableFill update = new TableFill("update", FieldFill.INSERT_UPDATE);
        TableFill creat = new TableFill("creat", FieldFill.INSERT);
        ArrayList<TableFill> tableFills = new ArrayList<>();
        tableFills.add(creat);
        tableFills.add(update);
        strategyConfig.setTableFillList(tableFills);
                //乐观锁配置
        strategyConfig.setVersionFieldName("version");//乐观锁
        mp.setStrategy(strategyConfig);

        mp.execute();
    }
}

运行完成后 得到如下

 

 

### 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、付费专栏及课程。

余额充值