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. HTML-CSS写抽屉网的置顶区域

    1.在pycharm的已有工程中新建一个html文件. 2.在<body></body>标签内部写入要内容: <div class='head-box' > < ...

  2. node 跨域问题

    node跨域有很多方法 1.引入 中间件cors 我觉的最好的方法 var express=require('express'); var cors=require('cors'); var app= ...

  3. python之if循环

    if 条件: if语句块else: 语句块 money = int(input("请输入你兜里的钱:")) if money > 500: print("吃肉&qu ...

  4. Fiddler抓包使用教程-Https

    转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/72956016 本文出自[赵彦军的博客] 开启 Https 抓包 Fiddler 默 ...

  5. 心迹 使用说明&功能展示

    下载地址 心迹.apk 更新于2018.8.9 11:47 测试账号:用户名testing,密码testing 项目地址 GitHub 注册&登录 第一次使用心迹app时,必须进行注册,以便区 ...

  6. 10-openldap同步原理

    openldap同步原理 阅读视图 openldap同步原理 syncrepl.slurpd同步机制优缺点 OpenLDAP同步条件 OpenLDAP同步参数 1. openldap同步原理 Open ...

  7. CSS| 框模型-border

    CSS 边框属性

  8. 统计分页一些sql

    USE [QPTreasureDB] GO /****** Object: StoredProcedure [dbo].[GameStatistics] Script Date: 2018/8/16 ...

  9. 进入正在运行的 docker 容器(docker container)

    在使用 docker 容器的时候,我们总会想看看容器内部长什么样子:我们使用 docker exec 命令可以满足我们的期望: ➜ compose docker exec --help Usage: ...

  10. tidb集群某个节点报错之:node_exporter-9100.service failed

    今天启动集群tidb时出现一个错误,是某个tikv节点报错:node_exporter-9100.service  failed 一个节点的问题会导致整个集群启动失败.去此节点下的日志文件中查找,发现 ...