1、mybatis-generator 概述

MyBatis官方提供了逆向工程 mybatis-generator,可以针对数据库表自动生成MyBatis执行所需要的代码(如Mapper.java、Mapper.xml、POJO)。mybatis-generator 有三种用法:命令行、eclipse插件、maven插件。而maven插件的方式比较通用,本文也将概述maven插件的使用方式。

2、pom.xml中配置plugin

<build>
<plugins>
<!-- mybatis-generator -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.2</version>
<configuration>
<!-- mybatis-generator的配置文件,根据情况调整位置 -->
<configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
<verbose>true</verbose>
<overwrite>true</overwrite>
</configuration>
<executions>
<execution>
<id>Generate MyBatis Artifacts</id>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.2</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
31
 
1
<build>
2
    <plugins>
3
        <!-- mybatis-generator -->
4
        <plugin>
5
            <groupId>org.mybatis.generator</groupId>
6
            <artifactId>mybatis-generator-maven-plugin</artifactId>
7
            <version>1.3.2</version>
8
            <configuration>
9
                <!-- mybatis-generator的配置文件,根据情况调整位置 -->
10
                <configurationFile>src/main/resources/generatorConfig.xml</configurationFile>
11
                <verbose>true</verbose>
12
                <overwrite>true</overwrite>
13
            </configuration>
14
            <executions>
15
                <execution>
16
                    <id>Generate MyBatis Artifacts</id>
17
                    <goals>
18
                        <goal>generate</goal>
19
                    </goals>
20
                </execution>
21
            </executions>
22
            <dependencies>
23
                <dependency>
24
                    <groupId>org.mybatis.generator</groupId>
25
                    <artifactId>mybatis-generator-core</artifactId>
26
                    <version>1.3.2</version>
27
                </dependency>
28
            </dependencies>
29
        </plugin>
30
    </plugins>
31
</build>

3、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> <!--JDBC驱动jar包的位置-->
<classPathEntry location="C:/workspace/project/learning/mybatis/lib/mysql-connector-java-5.1.6.jar"/> <context id="default" targetRuntime="MyBatis3"> <!--创建Java类时是否取消生成注释-->
<commentGenerator>
<property name="suppressDate" value="true"/>
<property name="suppressAllComments" value="true"/>
</commentGenerator> <!--JDBC数据库连接-->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/test"
userId="root"
password="dev">
</jdbcConnection> <!--
Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类
targetPackage 指定生成的model生成所在的包名
targetProject 指定在该项目下所在的路径
-->
<javaModelGenerator targetPackage="dulk.learn.mybatis.generator.pojo"
targetProject="./src/main/java">
<!-- 是否允许子包,即targetPackage.schemaName.tableName -->
<property name="enableSubPackages" value="false"/>
<!-- 是否对model添加构造函数 -->
<property name="constructorBased" value="true"/>
<!-- 是否对类CHAR类型的列的数据进行trim操作 -->
<property name="trimStrings" value="true"/>
<!-- 建立的Model对象是否 不可改变 即生成的Model对象不会有 setter方法,只有构造方法 -->
<property name="immutable" value="false"/>
</javaModelGenerator> <!--
mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件
-->
<sqlMapGenerator targetPackage="generator"
targetProject="./src/main/resources">
<property name="enableSubPackages" value="false"/>
</sqlMapGenerator> <!--
客户端代码,生成易于使用的针对Model对象和XML配置文件的代码
type="ANNOTATEDMAPPER",生成Java Model和基于注解的Mapper对象
type="MIXEDMAPPER",生成基于注解的Java Model和相应的Mapper对象
type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口
-->
<javaClientGenerator type="XMLMAPPER"
targetPackage="dulk.learn.mybatis.generator.mapper"
targetProject="./src/main/java">
<property name="enableSubPackages" value="false"/>
</javaClientGenerator> <!--tables-->
<table tableName="author" domainObjectName="Author"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table>
<table tableName="book" domainObjectName="Book"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table> </context>
</generatorConfiguration>
x
 
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE generatorConfiguration
3
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
4
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
5

6
<generatorConfiguration>
7

8
    <!--JDBC驱动jar包的位置-->
9
    <classPathEntry location="C:/workspace/project/learning/mybatis/lib/mysql-connector-java-5.1.6.jar"/>
10

11
    <context id="default" targetRuntime="MyBatis3">
12

13
        <!--创建Java类时是否取消生成注释-->
14
        <commentGenerator>
15
            <property name="suppressDate" value="true"/>
16
            <property name="suppressAllComments" value="true"/>
17
        </commentGenerator>
18

19
        <!--JDBC数据库连接-->
20
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
21
                        connectionURL="jdbc:mysql://localhost:3306/test"
22
                        userId="root"
23
                        password="dev">
24
        </jdbcConnection>
25

26
        <!--
27
        Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类
28
        targetPackage     指定生成的model生成所在的包名
29
        targetProject     指定在该项目下所在的路径
30
        -->
31
        <javaModelGenerator targetPackage="dulk.learn.mybatis.generator.pojo"
32
                            targetProject="./src/main/java">
33
            <!-- 是否允许子包,即targetPackage.schemaName.tableName -->
34
            <property name="enableSubPackages" value="false"/>
35
            <!-- 是否对model添加构造函数 -->
36
            <property name="constructorBased" value="true"/>
37
            <!-- 是否对类CHAR类型的列的数据进行trim操作 -->
38
            <property name="trimStrings" value="true"/>
39
            <!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 -->
40
            <property name="immutable" value="false"/>
41
        </javaModelGenerator>
42

43
        <!--
44
        mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMap文件 
45
        -->
46
        <sqlMapGenerator targetPackage="generator"
47
                         targetProject="./src/main/resources">
48
            <property name="enableSubPackages" value="false"/>
49
        </sqlMapGenerator>
50

51
        <!-- 
52
        客户端代码,生成易于使用的针对Model对象和XML配置文件的代码
53
        type="ANNOTATEDMAPPER",生成Java Model和基于注解的Mapper对象
54
        type="MIXEDMAPPER",生成基于注解的Java Model和相应的Mapper对象
55
        type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口
56
        -->
57
        <javaClientGenerator type="XMLMAPPER"
58
                             targetPackage="dulk.learn.mybatis.generator.mapper"
59
                             targetProject="./src/main/java">
60
            <property name="enableSubPackages" value="false"/>
61
        </javaClientGenerator>
62

63

64
        <!--tables-->
65
        <table tableName="author" domainObjectName="Author"
66
               enableCountByExample="false" enableUpdateByExample="false"
67
               enableDeleteByExample="false" enableSelectByExample="false"
68
               selectByExampleQueryId="false">
69
        </table>
70
        <table tableName="book" domainObjectName="Book"
71
               enableCountByExample="false" enableUpdateByExample="false"
72
               enableDeleteByExample="false" enableSelectByExample="false"
73
               selectByExampleQueryId="false">
74
        </table>
75

76
    </context>
77
</generatorConfiguration>

有些默认配置不必显性去配置,所以简化一下快速配置的话也可以这样:
(注意:配置中文件的生成地址等根据个人实际情况进行调整,另外,若有其他配置想要调整请参考官方文档)
<?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 location="C:/workspace/project/learning/mybatis/lib/mysql-connector-java-5.1.6.jar"/> <context id="default" targetRuntime="MyBatis3"> <commentGenerator>
<property name="suppressDate" value="true"/>
<property name="suppressAllComments" value="true"/>
</commentGenerator> <jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/test"
userId="root"
password="dev">
</jdbcConnection> <javaModelGenerator targetPackage="dulk.learn.mybatis.generator.pojo"
targetProject="./src/main/java">
<property name="trimStrings" value="true"/>
</javaModelGenerator> <sqlMapGenerator targetPackage="generator"
targetProject="./src/main/resources">
</sqlMapGenerator> <javaClientGenerator type="XMLMAPPER"
targetPackage="dulk.learn.mybatis.generator.mapper"
targetProject="./src/main/java">
</javaClientGenerator> <table tableName="author" domainObjectName="Author"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table>
<table tableName="book" domainObjectName="Book"
enableCountByExample="false" enableUpdateByExample="false"
enableDeleteByExample="false" enableSelectByExample="false"
selectByExampleQueryId="false">
</table> </context>
</generatorConfiguration>
 
1
<?xml version="1.0" encoding="UTF-8"?>
2
<!DOCTYPE generatorConfiguration
3
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
4
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
5

6
<generatorConfiguration>
7

8
    <classPathEntry location="C:/workspace/project/learning/mybatis/lib/mysql-connector-java-5.1.6.jar"/>
9

10
    <context id="default" targetRuntime="MyBatis3">
11

12
        <commentGenerator>
13
            <property name="suppressDate" value="true"/>
14
            <property name="suppressAllComments" value="true"/>
15
        </commentGenerator>
16

17
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
18
                        connectionURL="jdbc:mysql://localhost:3306/test"
19
                        userId="root"
20
                        password="dev">
21
        </jdbcConnection>
22

23
        <javaModelGenerator targetPackage="dulk.learn.mybatis.generator.pojo"
24
                            targetProject="./src/main/java">
25
            <property name="trimStrings" value="true"/>
26
        </javaModelGenerator>
27

28
        <sqlMapGenerator targetPackage="generator"
29
                         targetProject="./src/main/resources">
30
        </sqlMapGenerator>
31

32
        <javaClientGenerator type="XMLMAPPER"
33
                             targetPackage="dulk.learn.mybatis.generator.mapper"
34
                             targetProject="./src/main/java">
35
        </javaClientGenerator>
36

37
        <table tableName="author" domainObjectName="Author"
38
               enableCountByExample="false" enableUpdateByExample="false"
39
               enableDeleteByExample="false" enableSelectByExample="false"
40
               selectByExampleQueryId="false">
41
        </table>
42
        <table tableName="book" domainObjectName="Book"
43
               enableCountByExample="false" enableUpdateByExample="false"
44
               enableDeleteByExample="false" enableSelectByExample="false"
45
               selectByExampleQueryId="false">
46
        </table>
47

48
    </context>
49
</generatorConfiguration>

另,配置文件中诸如 javaModelGenerator / sqlMapGenerator / javaClientGenerator 等配置的顺序不要轻易改变,可能会导致插件执行时失败。

4、使用方式

mvn mybatis-generator:generate
如果是在IDEA环境中,直接鼠标点击执行即可:

目录结构如下:

注:建表时,字段名称建议用"_"分隔多个单词,比如:author_id...,这样生成的model,属性名称就会变成的驼峰命名,即:authorId

5、参考链接



[06] 利用mybatis-generator自动生成代码的更多相关文章

  1. SpringBoot 添加mybatis generator 自动生成代码插件

    自动生成数据层代码,提高开发效率 1.pom添加插件,并指定配置文件路径 <!-- mybatis generator 自动生成代码插件 --> <plugin> <gr ...

  2. idea中mybatis generator自动生成代码配置 数据库是sqlserver

    好长时间没有写博客了,最近公司要用java语言,开始学习java,属于初学者,今天主要记录一下mybatis generator自动生成代码,首先在如下图的目录中新建两个文件,如下图 generato ...

  3. SpringBoot入门篇--整合mybatis+generator自动生成代码+druid连接池+PageHelper分页插件

    原文链接 我们这一篇博客讲的是如何整合Springboot和Mybatis框架,然后使用generator自动生成mapper,pojo等文件.然后再使用阿里巴巴提供的开源连接池druid,这个连接池 ...

  4. IDEA Maven Mybatis generator 自动生成代码

    IDEA Maven Mybatis generator 自动生成代码 一.安装配置maven以及在Idea中配置maven 安装过程步骤可以看上面的博文,里面介绍得很详细. 二.建数据表 DROP ...

  5. IDEA Maven Mybatis generator 自动生成代码(实例讲解)(转)

    IDEA Maven Mybatis generator 自动生成代码(实例讲解) MyBatis Generator • 简称MBG,是一个专门为MyBatis框架使用者定制的代码生成器,可以快速的 ...

  6. 使用Mybatis Generator自动生成代码

    MyBatis Generator(MBG)是MyBatis MyBatis 和iBATIS的代码生成器.它将为所有版本的MyBatis以及版本2.2.0之后的iBATIS版本生成代码.它将内省数据库 ...

  7. Mybatis generator 自动生成代码(2)

    最近准备开始做一个项目,需要开始手动创建sql,于是将Mybatis generator 工具功能强化了下. 首先,这里引入到版本一点的包 <dependency> <groupId ...

  8. Mybatis generator 自动生成代码

    开发项目的时候,表很多,是不可能一点点的自己去写xml ,dao文件的,这里就需要用到代码的自动生成工具了. 第一步:导入jar包,当然,这之前,基本环境,像mybatis,数据库之类的都得搭建好. ...

  9. IDEA使用mybatis generator自动生成代码

    主要就三步: 1.pom 文件中引入jar包并配置 build 属性 <dependencies> <!-- 自动生产mapper Begin! --> <depende ...

  10. mybatis generator自动生成代码时 只生成了insert 而没有其他的

    mybatis框架提供了非常好用的逆向工程插件,但是在使用过程中会有很多问题. 我在使用中就遇到了只生成insert和insertSeletive方法,而不生成其他根据primary key查询更新删 ...

随机推荐

  1. JavaScript 频繁发射事件处理的优化 --- 函数节流/事件稀释

    引子:昨天面试时面试官问了如何实现一个固定导航栏,在我答完后面试官问我可能存在哪些问题,如何优化? 这个问题我答得不太好,但现在回想起来应该有两个问题: 1. 把 fixbar元素 position: ...

  2. NoHttp封装--05 文件下载

    xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:la ...

  3. (后端)Java跨域过滤器

    private FilterConfig config = null; @Override public void init(FilterConfig config) throws ServletEx ...

  4. Appium学习——安装Android SDK

    .下载Android SDK 下载地址:http://tools.android-studio.org/index.php/sdk 百度搜索Android SDK也可以. 下载之后,Android S ...

  5. python第十七天---时间模块、random模块

    作完一个作业,开始新的学习: 有由今天的时间有限所有学习了以下两个模块,明天继续! 时间模块.random模块 import time #!usr/bin/env python #-*-coding: ...

  6. python 计时累积超过24小时时继续往上累加

    最近在做一个工具,要求在工具上面加上程序运行的时间,所以做了个计时器 在网上找了很多发现都是24小时制的,超过24小时后就会回0 然后自己根据24小时制修改了一个不停累加时间的 若是想超过24小时后以 ...

  7. win10系统如何关掉系统自动更新

    越来越多的电脑使用者都在使用Windows10系统,尽管系统是一代代更新的,但难免有槽点,Windows10系统也不例外,最大的槽点就是“自动更新”的功能.当然,“自动更新”的功能也是相当有用处的.  ...

  8. ccf-20171203 Crontab问题

    这题有如下几个点要注意: 1.最开始输出的开始时间和截止时间,这里是不包含截止时间的. 2.月份和星期的英文表示是大小写任意的,并未规定必须是Sat这种形式. 3.星期天的数字标识是0. 我的思路是, ...

  9. January 05th, 2018 Week 01st Friday

    You can't make decisions based on fear and the possibility of what might happen. 不要因为恐惧未知的可能而妄下决定. P ...

  10. python基础 - 控制语句

    判断-if mood = True if mood: print('mood ok'); else: print('mood not OK') if-elif-else if a == 1: pass ...