MybatisPlus代码生成器(官方自带),main代码和pom依赖文件

该博客展示了如何利用MyBatisPlus的AutoGenerator类来生成Java项目代码,包括配置全局信息、数据源、策略以及包信息,旨在简化数据库表与Java实体类之间的映射工作。主要涉及数据库连接、表名转换策略以及生成的类如Controller、Service、Mapper等。
摘要由CSDN通过智能技术生成

1、main代码

package com.wl;

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.NamingStrategy;

/**
 * MyBatis Plus代码自动生成类
 *
 */
public class MybatisPlusGenerator {

    public static void main(String[] args) {

        AutoGenerator autoGenerator = new AutoGenerator();

        //全局配置
        GlobalConfig gc = new GlobalConfig();
        String oPath = System.getProperty("user.dir");  //得到当前项目的路径
        gc.setOutputDir(oPath + "/src/main/java");   //生成文件输出根目录
        gc.setOpen(false);//生成完成后不弹出文件框,true为弹出
        gc.setFileOverride(true);  //文件覆盖
        gc.setActiveRecord(false);// 不需要ActiveRecord特性的请改为false
        gc.setEnableCache(false);// XML 二级缓存
        gc.setBaseResultMap(true);// XML ResultMap
        gc.setBaseColumnList(false);// XML columList
        gc.setAuthor("ljj");// 作者

        // 自定义文件命名,注意 %s 会自动填充表实体属性!
        gc.setControllerName("%sController");       //所有Controller类都是Controller结尾的
        gc.setServiceName("%sService");
        gc.setServiceImplName("%sServiceImpl");
        gc.setMapperName("%sMapper");
        gc.setXmlName("%sMapper");
        //gc.setIdType(IdType.ID_WORKER);         //设置主键id的配置,过期了,建议不要用
        autoGenerator.setGlobalConfig(gc);          //glob 全球的

        // 数据源配置
        DataSourceConfig dsc = new DataSourceConfig();      //算是连接数据库,自行修改
        dsc.setDbType(DbType.MYSQL);   //设置数据库类型
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("1111");
        //dsc.setPassword("gosuncn");
        dsc.setUrl("jdbc:mysql://localhost:3306/life-admin?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC");
        //dsc.setUrl("jdbc:mysql://192.168.255.99:3306/life-admin?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC");
        autoGenerator.setDataSource(dsc);

        // 策略配置
        StrategyConfig strategy = new StrategyConfig();
        strategy.setNaming(NamingStrategy.underline_to_camel);      // 表名生成策略
        strategy.setInclude(new String[] { "cmy_political_businessman_help" });     // 需要生成的表,cmy_political_hometown_scenery
        strategy.setTablePrefix("cmy_political_"); // 表名前缀
        //strategy.setSuperServiceClass(null);
        //strategy.setSuperServiceImplClass(null);
        strategy.setSuperMapperClass(null);
        autoGenerator.setStrategy(strategy);

        // 包配置
        PackageConfig pc = new PackageConfig();
        pc.setParent("com.atguigu.admin.test");            //配置父包
        //pc.setModuleName("model");      //配置模块名称,相当于包名,所有生成的文件都将放在该包下
        pc.setController("controller");     //存在默认值,默认值即controller,开源可自己看源码
        pc.setService("service");
        pc.setServiceImpl("service.impl");
        pc.setMapper("mapper");
        pc.setEntity("entity");
        pc.setXml("xml");
        autoGenerator.setPackageInfo(pc);

        // 执行生成
        autoGenerator.execute();
    }

}

2、pom依赖文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.wl</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>mybatis-plus-generator</name>
    <description>mybatis-plus自动生成代码模块</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.2</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis Plus提供了一个强大的代码生成器,它可以帮助我们自动生成MyBatis Plus框架的代码。要使用代码生成器,我们需要完成以下步骤: 1. 配置数据库连接:在项目的配置文件中,配置数据库相关信息,例如数据库驱动、连接地址、用户名和密码等。 2. 添加依赖:在项目的pom.xml文件中添加MyBatis Plus的依赖项。 3. 配置代码生成器:在项目的配置文件中,配置代码生成器相关信息,例如输出路径、包名、表名等。 4. 运行代码生成器:编写一个Java类,使用MyBatis Plus提供的代码生成器API,创建并执行生成代码的任务。 下面是一个示例代码,演示了如何使用MyBatis Plus的代码生成器生成Mapper、Service、Controller等代码: ```java import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.generator.AutoGenerator; import com.baomidou.mybatisplus.generator.InjectionConfig; import com.baomidou.mybatisplus.generator.config.*; import com.baomidou.mybatisplus.generator.config.po.TableFill; import com.baomidou.mybatisplus.generator.config.rules.DateType; import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy; import java.util.ArrayList; import java.util.List; public class CodeGenerator { public static void main(String[] args) { // 1. 全局配置 GlobalConfig globalConfig = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); globalConfig.setOutputDir(projectPath + "/src/main/java"); globalConfig.setAuthor("Your Name"); globalConfig.setOpen(false); globalConfig.setIdType(IdType.AUTO); globalConfig.setDateType(DateType.ONLY_DATE); // 2. 数据源配置 DataSourceConfig dataSourceConfig = new DataSourceConfig(); dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/mybatisplus?useUnicode=true&characterEncoding=utf8&useSSL=false"); dataSourceConfig.setDriverName("com.mysql.jdbc.Driver"); dataSourceConfig.setUsername("root"); dataSourceConfig.setPassword("root"); // 3. 包配置 PackageConfig packageConfig = new PackageConfig(); packageConfig.setParent("com.example.mybatisplus"); packageConfig.setModuleName("module"); // 4. 策略配置 StrategyConfig strategyConfig = new StrategyConfig(); strategyConfig.setNaming(NamingStrategy.underline_to_camel); strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel); strategyConfig.setEntityLombokModel(true); strategyConfig.setRestControllerStyle(true); strategyConfig.setControllerMappingHyphenStyle(true); List<TableFill> tableFillList = new ArrayList<>(); tableFillList.add(new TableFill("create_time", FieldFill.INSERT)); tableFillList.add(new TableFill("update_time", FieldFill.INSERT_UPDATE)); strategyConfig.setTableFillList(tableFillList); // 5. 自定义配置 InjectionConfig injectionConfig = new InjectionConfig() { @Override public void initMap() { // do nothing } }; // 6. 代码生成器 AutoGenerator autoGenerator = new AutoGenerator(); autoGenerator.setGlobalConfig(globalConfig); autoGenerator.setDataSource(dataSourceConfig); autoGenerator.setPackageInfo(packageConfig); autoGenerator.setStrategy(strategyConfig); autoGenerator.setCfg(injectionConfig); // 7. 执行生成代码任务 autoGenerator.execute(); } } ``` 在运行这个代码之前,请确保数据库连接信息正确,并且已经在数据库中创建了相应的表。执行代码后,生成的代码将会保存在指定的输出路径下,我们可以在项目中直接使用这些生成的代码。 希望对你有所帮助!如果有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值