基于generator链接数据库实现实体类、controller、mapper、mapper.xml、service、impl的自动生成

1、查了很多csdn的博客,发现只有生成实体类的generator配置,并没有自动生成service等java文件的配置

1.1、对于我这种懒人当然是不能容忍的

2、如何使用generator生成service、impl、controller、entity、mapper、mapper.xml

话不多说,上代码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
    <!-- context 是逆向工程的主要配置信息 -->
    <!-- id:起个名字 -->
    <!-- targetRuntime:设置生成的文件适用于那个 mybatis 版本 -->
    <context id="default" targetRuntime="MyBatis3" defaultModelType="flat" >
        <!--此处的plugin标签为自己封装的自动生成service、impl、controller的.class-->
        <!--需使用我提供的jar包方可使用哦-->
        <plugin type="org.mybatis.generator.plugins.ServiceAndControllerGeneratorPlugin" >
        <property name="targetProject" value="./src/main/java"/>
        <property name="servicePackage" value="cn.pms.goal.service"/>
        <property name="serviceImplPackage" value="cn.pms.goal.service.impl"/>
        <property name="controllerPackage" value="cn.pms.goal.controller"/>
        <!--UserService,该值则为Service-->
        <property name="serviceSuffix" value="Service"/>
        <!--Service接口的父接口-->
        <property name="superServiceInterface" value="org.aurochsframework.boot.commons.service.GeneralService"/>
        <!--ServiceImpl的父类-->
        <property name="superServiceImpl" value="org.aurochsframework.boot.commons.service.AbstractGeneralService"/>
        <!--controller的父类接口-->
        <property name="superController" value="org.aurochsframework.boot.commons.controller.GeneralCrudController"/>
        </plugin>
        <plugin type="org.mybatis.generator.plugins.LombokPlugin">
            <property name="hasLombok" value="true"/>
        </plugin>
        <!--optional,指在创建class时,对注释进行控制-->
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <!-- 是否去除自动生成的注释 true:是 : false:-->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--jdbc的数据库连接 wg_insert 为数据库名字-->
        <!--可以使用oracle、mysql,我现在用的是oracle-->
        <jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver"
                        connectionURL="***你的链接路径***"
                        userId="**用户名**"
                        password="*密码*"></jdbcConnection>
        <!--非必须,类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver>
            <!-- 默认情况下数据库中的 decimal,bigInt 在 Java 对应是 sql 下的 BigDecimal 类 -->
            <!-- 不是 double 和 long 类型 -->
            <!-- 使用常用的基本类型代替 sql 包下的引用类型 -->
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>
        <!-- targetPackage:生成的实体类所在的包 -->
        <!-- targetProject:生成的实体类所在的硬盘位置 -->
        <javaModelGenerator targetPackage="cn.wwkj.pms.goal.entity.po"
                            targetProject="src/main/java">
            <!-- 是否允许子包 -->
            <property name="enableSubPackages" value="false"/>
            <!-- 是否对modal添加构造函数 -->
            <property name="constructorBased" value="true"/>
            <!-- 是否清理从数据库中查询出的字符串左右两边的空白字符 -->
            <property name="trimStrings" value="true"/>
            <!-- 建立modal对象是否不可改变 即生成的modal对象不会有setter方法,只有构造方法 -->
            <property name="immutable" value="false"/>
        </javaModelGenerator>
        <!-- targetPackage 和 targetProject:生成的 mapper 文件的包和位置 -->
        <sqlMapGenerator targetPackage="cn.pms.goal.mapper.mapper"
                         targetProject="src/main/java">
            <!-- 针对数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>
        <!-- targetPackage 和 targetProject:生成的 interface 文件的包和位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="cn.pms.goal.mapper" targetProject="src/main/java">
            <!-- 针对 oracle 数据库的一个配置,是否把 schema 作为字包名 -->
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>
        <!-- tableName是数据库中的表名,domainObjectName是生成的JAVA模型名,后面的参数不用改,要生成更多的表就在下面继续加table标签 schema属性解决了generator的mapper.xml重复生成的问题-->
        <!--tableName根据当然就是数据库的表名称啦                               主要防小白-->
        <table tableName="PROJ_GOAL_BILL" schema="WWAPP_YSJX_AYS" domainObjectName="ProjGoalBill"
               enableInsert="false"
               enableSelectByPrimaryKey="true"
               enableSelectByExample="false"
               enableUpdateByPrimaryKey="false"
               enableCountByExample="false"
               enableDeleteByPrimaryKey="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="Oracle" identity="true"/>
        </table>
    </context>
</generatorConfiguration>

3、在pom中引入generator

<!--generator自动生成实体类-->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.5</version>
        </dependency>
<!--generator自动生成实体类-->
<plugin>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.5</version>
            <configuration>
               <!-- 在控制台打印执行日志 -->
               <verbose>true</verbose>
               <!-- 重复生成时会覆盖之前的文件-->
               <overwrite>true</overwrite>
                    <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
               </configuration>
                <!-- 引入链接数据库的jar包-->
                <dependencies>
                    <dependency>
                        <groupId>com.oracle</groupId>
                        <artifactId>ojdbc14</artifactId>
                        <version>10.2.0.5.0</version>
                    </dependency>
                </dependencies>
</plugin>

4、最后附上jar包下载地址引入替换自己的generator即可

https://download.csdn.net/download/m0_46657452/12840691

5、最后最后最后最后附上要替换的jar包教程

Alt

6.如何使用

在resources下添加generatorConfig.xml,因为已经引入了generatorjar包依赖,所以在右侧maven菜单中直接点击运行即可
在resources下添加generatorConfig.xml,因为已经引入了generatorjar包依赖,所以在右侧maven菜单中直接点击运行即可

7.效果

在这里插入图片描述

如果需要generator修改后的jar包依赖请联系

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在使用 MyBatis-Plus 时,可以通过使用 MyBatis-Plus 的代码生成器来自动生成实体类。具体步骤如下: 1. 配置 pom.xml 文件,添加 MyBatis-Plus 的依赖。 2. 在项目的 resources 目录下创建 generator 目录,并在该目录下创建 generatorConfig.xml 配置文件,在该文件中配置代码生成器的相关信息,包括数据库连接信息、生成文件保存路径、生成的表配置等。 3. 在代码中编写代码生成器的启动类,通过配置文件的方式加载配置信息,生成代码。 4. 运行代码生成器启动类,即可自动生成实体类Mapper 接口以及 XML 映射文件。 下面是一个简单的示例: 1. pom.xml 文件中添加 MyBatis-Plus 的依赖: ``` <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> ``` 2. 在 resources 目录下创建 generator 目录,并在该目录下创建 generatorConfig.xml 配置文件,配置文件内容如下: ``` <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <generatorConfiguration> <context id="MySqlContext" targetRuntime="MyBatis3"> <!-- 数据库连接信息 --> <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false" userId="root" password="root"> </jdbcConnection> <!-- Java 模型生成器配置,生成实体类 --> <javaModelGenerator targetPackage="com.example.entity" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- Mapper.xml 文件生成器配置,生成 XML 映射文件 --> <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"> <property name="enableSubPackages" value="true"/> </sqlMapGenerator> <!-- Mapper 接口生成器配置,生成 Mapper 接口 --> <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.mapper" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!-- 表配置,生成指定表的代码 --> <table tableName="user"/> </context> </generatorConfiguration> ``` 3. 在代码中编写代码生成器启动类,如下所示: ``` public class CodeGenerator { public static void main(String[] args) { // 代码生成器 AutoGenerator mpg = new AutoGenerator(); // 全局配置 GlobalConfig gc = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java"); gc.setAuthor("your name"); gc.setOpen(false); // 实体属性 Swagger2 注解 gc.setSwagger2(true); mpg.setGlobalConfig(gc); // 数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("root"); mpg.setDataSource(dsc); // 包配置 PackageConfig pc = new PackageConfig(); pc.setModuleName(null); pc.setParent("com.example"); pc.setEntity("entity"); pc.setMapper("mapper"); pc.setService("service"); pc.setServiceImpl("service.impl"); pc.setController("controller"); mpg.setPackageInfo(pc); // 配置模板 TemplateConfig templateConfig = new TemplateConfig(); templateConfig.setXml(null); mpg.setTemplate(templateConfig); // 策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setNaming(NamingStrategy.underline_to_camel); strategy.setColumnNaming(NamingStrategy.underline_to_camel); strategy.setEntityLombokModel(true); strategy.setRestControllerStyle(true); // 公共父类 strategy.setSuperControllerClass("com.example.controller.BaseController"); // 写于父类中的公共字段 strategy.setSuperEntityColumns("id"); strategy.setInclude("user"); strategy.setControllerMappingHyphenStyle(true); mpg.setStrategy(strategy); mpg.execute(); } } ``` 4. 运行 CodeGenerator 类,即可自动生成实体类Mapper 接口以及 XML 映射文件。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值