mybatis.generator自动生成代码使用介绍(maven插件)

1.首先在项目的pom文件中加入如下的代码片段,进行插件配置

 <build>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.5</version>
                <configuration>
                    <!--项目中mybatis-generator.xml配置文件的位置,一定要保证正确-->
                    <configurationFile>src\main\resources\mybatis-generator\generatorConfig.xml</configurationFile>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>${mysql-connector}</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>

2.第二部分配置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>
    <properties resource="mybatis-generator/generator.properties"/>
    <context id="my" targetRuntime="MyBatis3" defaultModelType="flat">

        <!--自动实现Serializable接口-->
        <plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>


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

        <!--数据库基本信息-->
        <jdbcConnection driverClass="${jdbc.driverClass}"
                        connectionURL="${jdbc.connectionURL}"
                        userId="${jdbc.user}"
                        password="${jdbc.password}">
        </jdbcConnection>

        <!--生成实体类的位置以及包的名字-->
        <javaModelGenerator targetPackage="${model.TargetPackage}" targetProject="${model.TargetProject}">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="true" />
            <!-- 从数据库返回的值被清理前后的空格 -->
            <property name="trimStrings" value="true" />
        </javaModelGenerator>

        <!--生成映射文件存放位置-->
        <sqlMapGenerator targetPackage="${mapper.XMLTargetPackage}" targetProject="${mapper.XmlTargetProject}">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!--生成Dao类存放位置,mapper接口生成的位置-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="${dao.TargetPackage}" targetProject="${dao.TargetProject}">
            <!-- enableSubPackages:是否让schema作为包的后缀 -->
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>

        <!-- 配置表信息 -->
        <!-- schema即为数据库名 tableName为对应的数据库表 domainObjectName是要生成的实体类 enable*ByExample
            是否生成 example类 -->
        <table schema="${dbName}" tableName="${tableName}"
               domainObjectName="${domainObjectName}" enableCountByExample="false"
               enableDeleteByExample="false" enableSelectByExample="false"
               enableUpdateByExample="false">
        </table>
    </context>
</generatorConfiguration>

3.其中xml文件中的可以引用配置文件,这里我们引用配置文件generator.properties

#数据库连接信息
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.connectionURL=###
jdbc.user=###
jdbc.password=###

#实体类位置
model.TargetPackage=###
model.TargetProject=src/main/java

#mapper.xml文件位置
mapper.XMLTargetPackage=mapper
mapper.XmlTargetProject=src/main/resources

#dao文件位置
dao.TargetPackage=###
dao.TargetProject=src/main/java

#数据库名
dbName=###

#需要生产的表名
tableName=###

#指定生成实体类名
domainObjectName=###

配置完之后在项目中就可以运用maven插件生成map.xml,实体类,dao类,可以很大的提高开发效率。

猜你喜欢

转载自blog.csdn.net/Gavin_wangzg/article/details/80782096