SpringBoot系列: 使用MyBatis maven插件自动生成java代码

====================================
pom.xml 文件
====================================
需要在 pom.xml 文件增加 mybatis-generator-maven 插件, mybatis-generator maven 插件默认会读到 src/main/resources目录下的 generatorConfig.xml 文件, 也可以自定义 generatorConfig.xml的路径.

<plugin>
    <groupId>org.mybatis.generator</groupId>
    <artifactId>mybatis-generator-maven-plugin</artifactId>
    <configuration>
        <verbose>true</verbose>
        <overwrite>true</overwrite>
         <!--配置文件的路径-->
         <configurationFile>${basedir}/src/main/resources/generatorConfig.xml</configurationFile> 
    </configuration>
</plugin>

====================================
generatorConfig.properties 文件
====================================

src/main/resources目录下的新建 generatorConfig.properties 文件, 该文件将被generatorConfig.xml引用, 在其中定义一些和环境相关的变量, 比如jar 驱动的路径. 

mybatisDriverJarPath=C:\\Users\\Administrator\\.m2\\repository\\mysql\\mysql-connector-java\\5.1.46\\mysql-connector-java-5.1.46.jar
mybatisDriverClassName=com.mysql.jdbc.Driver
mybatisJdbcUrl=jdbc:mysql://localhost/world
mybatisJdbcUser=root
mybatisJdbcPassword=toor
mybatisJavaModelPackage=com.springbootmybatis.mybatissample.entity
mybatisSqlMapPackage=com.springbootmybatis.mybatissample.mapper
mybatisDaoPackage=com.springbootmybatis.mybatissample.dao

====================================
generatorConfig.xml 文件
====================================
src/main/resources目录下的新建 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>
    <!--配置文件[可选项], 引入配置文件后, 在下面的Xml内容中可以使用${configItem}的方式来设定属性值, 比如jdbc用户名 -->
    <properties resource="generatorConfig.properties" />

    <!-- 必须配置驱动包的路径 -->
    <classPathEntry location="${mybatisDriverJarPath}" />

    <context id="MysqlTables" targetRuntime="MyBatis3">
        <!-- 生成的pojo,将implements Serializable/Hashcode/ToString方法 -->
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
        <plugin
            type="org.mybatis.generator.plugins.EqualsHashCodePlugin"></plugin>
        <plugin type="org.mybatis.generator.plugins.ToStringPlugin"></plugin>

        <commentGenerator>
            <!-- 是否去除自动生成的注释 -->
            <property name="suppressAllComments" value="false" />

            <!-- 这个元素用来去除指定生成的注释中是否包含生成的日期 -->
            <!-- 如果生成日期,会造成即使修改一个字段,整个实体类所有属性都会发生变化,不利于版本控制,所以设置为true -->
            <property name="suppressDate" value="true" />
        </commentGenerator>

        <jdbcConnection driverClass="${mybatisDriverClassName}"
            connectionURL="${mybatisJdbcUrl}" userId="${mybatisJdbcUser}"
            password="${mybatisJdbcPassword}">
        </jdbcConnection>


        <javaTypeResolver>
            <!-- 使用Java的 Integer而不是java.math.BigDecimal来对应DB中的 DECIMAL 和 NUMERIC 类型 -->
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>

        <!-- 指定生成pojo的包和此包在项目中的地址; -->
        <javaModelGenerator
            targetPackage="${mybatisJavaModelPackage}"     targetProject="src\main\java">
            <!-- 是否在当前路径下新加一层, 新的一层以db schema作为目录名 -->
            <property name="enableSubPackages" value="false" />
        </javaModelGenerator>

        <!--对应的mapper.xml文件 -->
        <sqlMapGenerator
            targetPackage="${mybatisSqlMapPackage}" targetProject="src\main\java">
            <!-- 是否在当前路径下新加一层, 新的一层以db schema作为目录名 -->
            <property name="enableSubPackages" value="false" />
        </sqlMapGenerator>

        <!-- 对应的Mapper接口类文件 -->
        <javaClientGenerator type="XMLMAPPER"
            targetPackage="${mybatisDaoPackage}" targetProject="src\main\java">
            <!-- 是否在当前路径下新加一层, 新的一层以db schema作为目录名 -->
            <property name="enableSubPackages" value="false" />
        </javaClientGenerator>

        <!-- 需要生成entity的数据表, 该table节点可以多个 -->
        <table schema="world" tableName="city" domainObjectName="City"
            enableCountByExample="false" enableUpdateByExample="false"
            enableDeleteByExample="false" enableSelectByExample="false"
            selectByExampleQueryId="false">

            <!-- 用于指定生成实体类时是否使用实际的列名作为实体类的属性名, 如果要用Camel Case风格, 需要设置为false -->
            <property name="useActualColumnNames" value="false" />

            <!-- 字段重命名 -->
            <!--
            <columnOverride column="create_time"  property="createTime" />
            <columnOverride column="float_test"  property="floatTest" />
            <columnOverride column="double_test" property="doubleTest" />
            <columnOverride column="text_test" property="textTest" />
             -->

            <!-- 忽略列,不生成bean 字段 -->
            <!-- <ignoreColumn column="FRED" /> -->

            <!-- 指定列的java数据类型 -->
            <!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
        </table>
    </context>
</generatorConfiguration>

====================================
mvn mybatis-generator:generate 命令
====================================
执行 mvn mybatis-generator:generate 命令, 可生成对应Java entity类和 mapper.xml 和 java dao 接口.

====================================
参考
====================================
https://www.cnblogs.com/GaiDynasty/p/4088531.html
https://www.cnblogs.com/JsonShare/p/5521901.html
https://segmentfault.com/a/1190000009058867
https://blog.csdn.net/wangxy799/article/details/60870361
https://www.cnblogs.com/linhp/p/5884151.html
https://www.cnblogs.com/hyyq/p/7087620.html

猜你喜欢

转载自www.cnblogs.com/harrychinese/p/springboot_mybatis_code_gen.html