MyBatis代码生成器

一、创建普通maven项目(略)

二、导包

  

<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.2.1</version>
  </dependency>

  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
  </dependency>

  <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.2</version>
    <scope>test</scope>
  </dependency>

  <dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.0.0</version>
  </dependency>

  <build>
        <resources>
            <resource>
                <!--src/main/java下面所有的properties文件或者xml文件都要进行编译-->
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>

        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.5</version>
                <configuration>
                  <!--
                   加载指定的xml文件,如果不写,默认找的xml文件为generatorConfig.xml
                  <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>

                  -->
                    <!--代码生成器在日志信息-->
                    <verbose>true</verbose>
                    <!--是否覆盖java文件-->
                    <overwrite>true</overwrite>
                </configuration>
            </plugin>
        </plugins>
    </build>

三、配置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>
    <!--
       classPathEntry:可以配置多个,也不配置
       数据库驱动:这里找到相应的驱动jar包就可以了(注:不同数据库的jar不一样)
          location:里面的是路径(也可以直接写绝对路径 -> 如:E:\mybatis\mysql-connector-java-5.1.26-bin.jar)
    -->
    <classPathEntry   location="F:\tool\apache-maven-3.2.5-bin\repository-teacher\repository-teacher\mysql\mysql-connector-java\5.1.21\mysql-connector-java-5.1.21.jar"/>
    <!--
       context:用于生成一组对象的环境(至少配置1个,可以配置多个)
       id:表达唯一的名称
       targetRuntime:用于指定生成的代码的运行环境(MyBatis3/MyBatis3Simple)
          MyBatis3:默认值
          MyBatis3Simple:不会生成与Example(案例)相关的方法
    -->
    <context id="DB2Tables"   targetRuntime="MyBatis3Simple" >
        <!--
            用于配置如果生成注释信息(最多可以配置一下)
            suppressAllComments:阻止生成注释 ,默认为false
            suppressDate:阻止生成的注释 时间戳,默认为false
            addRemarkComments:注释是否添加数据库表的备注信息,默认为false
         -->
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--
           这个应该比较清楚,配置连接数据库的基本信息
        -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql:///mybatis"
                        userId="root" password="admin">
        </jdbcConnection>
        <!--
           用于指定JDBC类型和Java类型如何转换,最多可以配置一个
           forceBigDecimals:控制是否强制将DECIMAL和NUMERIC类型的JDBC字段转换成Java类型的 BigDecimal
                        默认为false,一般不需要配置
        -->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!--
           javaModelGenerator:用来控制生成的实体类
              targetPackage:生成Model类存放位置(包名)
              targetProject:指定目标项目路径(根目录)
              对应的子属性:
                 trimStrings:判断是否对数据库查询结果进行trim操作(默认false)
        -->
        <javaModelGenerator targetPackage="cn.itsource.domain" targetProject="src/main/java">
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!--
           sqlMapGenerator:生成映射文件存放位置(Mapper.xml文件)
              targetPackage:生成SQL映射文件(XML文件)在哪个包中
              targetProject:指定目标项目路径(根目录)
        -->
        <sqlMapGenerator targetPackage="cn.zhao.mapping" targetProject="src/main/resources">
        </sqlMapGenerator>

        <!--
           javaClientGenerator:Java客户端生成器(生成Dao/Mapper的接口)
                          该 标签可选(最多配置一个),如果不配置,就不会生成Mapper接口
              type:选择客户端代码生成器
                 MyBatis3
                    ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件
                    MIXEDMAPPER:XML和注解混合形式
                    XMLMAPPER:所有方法都在XML中(接口调用依赖XML)
                 MyBatis3Simple
                    ANNOTATEDMAPPER:基于注解的Mapper接口,不会有对应的XML映射文件
                    XMLMAPPER:所有方法都在XML中(接口调用依赖XML)
              targetPackage:生成Mapper接口存放的包名
              targetProject:指定目标项目路径
        -->
        <javaClientGenerator type="XMLMAPPER" targetPackage="cn.itsource.dao" targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!--
           table:生成对应表及类名
              tableName:对应表名(注:%代表所有)
              domainObjectName:对应的类名
              generatedKey:主键自增的id字段(针对当前 数据库配置MySQL)
        -->
        <table tableName="w_employee" domainObjectName="Employee"></table>
    </context>
</generatorConfiguration>

四、运行生成代码
  

 

运行结束后,代码就自动生成了

 

 

   

posted @ 2019-07-22 22:52  涂小二  阅读(252)  评论(0编辑  收藏  举报