MybatisPlus代码生成器

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这个版本的代码生成器我并未采用最新的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();
    }
}

运行完成后 得到如下

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值