MyBatis Generator简介

MyBatis Generator(MBG)是MyBatis MyBatis 和iBATIS的代码生成器。它将为所有版本的MyBatis以及版本2.2.0之后的iBATIS版本生成代码。它将内省数据库表(或许多表),并将生成可用于访问表的工件。这减少了设置对象和配置文件以与数据库表交互的初始麻烦。MBG寻求对简单CRUD(创建,检索,更新,删除)的大部分数据库操作产生重大影响。您仍然需要为连接查询或存储过程手动编写SQL和对象代码。

MyBatis Generator将生成:

  • 与表结构匹配的Java POJO。这可能包括:

    • 一个匹配表的主键的类(如果有主键)
    • 一个匹配表的非主键字段的类(BLOB字段除外)
    • 包含表的BLOB字段的类(如果表具有BLOB字段)
    • 用于启用动态选择,更新和删除的类

    这些类之间存在适当的继承关系。请注意,生成器可以配置为生成不同类型的POJO层次结构 - 例如,如果您愿意,可以选择为每个表生成单个域对象。

  • MyBatis / iBATIS兼容的SQL Map XML文件。MBG为配置中的每个表上的简单CRUD函数生成SQL。生成的SQL语句包括:
    • 插入
    • 按主键更新
    • 通过示例更新(使用动态where子句)
    • 按主键删除
    • 按示例删除(使用动态where子句)
    • 按主键选择
    • 按示例选择(使用动态where子句)
    • 以身作则

    根据表的结构,这些语句有不同的变体(例如,如果表没有主键,则MBG不会通过主键功能生成更新)。

  • 适当使用上述对象的Java客户端类。Java客户端类的生成是可选的。MBG将为MyBatis 3.x生成以下类型的Java客户端:
    • 适用于MyBatis 3.x映射器基础结构的映射器接口

    MBG将为iBATIS 2.x生成以下类型的Java客户端:

    • 符合Spring框架的DAO
    • 仅使用iBATIS SQL映射API的DAO。这些DAO可以生成两种:通过构造函数或setter注入提供SqlMapClient。
    • 符合iBATIS DAO框架的DAO(iBATIS的可选部分,现在不推荐使用此框架,我们建议您使用Spring框架)

MyBatis生成器设计为在迭代开发环境中运行良好,并且可以作为Ant任务或Maven插件包含在连续构建环境中。迭代运行MBG时需要注意的重要事项包括:

  1. 如果存在与新生成的XML文件同名的现有文件,MBG将自动合并XML文件。MBG不会覆盖您对其生成的XML文件所做的任何自定义更改。您可以反复运行它,而不必担心会丢失对XML的自定义更改。MBG将替换先前运行中生成的任何XML元素。
  2. MBG 不会合并Java文件,它可以覆盖现有文件或使用不同的唯一名称保存新生成的文件。如果对生成的Java文件进行更改并以迭代方式运行MBG,则必须手动合并更改。当作为Eclipse 插件运行时 ,MBG可以自动合并Java文件。

MyBatis Generator使用

第一步:新建generatorConfig.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfigurationPUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN""http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration><!--导入属性配置--><properties resource="generator.properties"></properties><!--指定特定数据库的jdbc驱动jar包的位置--><!--<classPathEntry location="${jdbc.driverLocation}"/>--><context id="default" targetRuntime="MyBatis3"><!-- optional,旨在创建class时,对注释进行控制,false生成注释,true无注释 --><commentGenerator><property name="suppressDate" value="false"/><property name="suppressAllComments" value="false"/></commentGenerator><!--jdbc的数据库连接 --><jdbcConnectiondriverClass="${jdbc.driverClass}"connectionURL="${jdbc.connectionURL}"userId="${jdbc.userId}"password="${jdbc.password}"></jdbcConnection><!--默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal--><!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制--><javaTypeResolver><property name="forceBigDecimals" value="false"/></javaTypeResolver><!-- Model模型生成器,用来生成含有主键key的类,记录类 以及查询Example类targetPackage     指定生成的model生成所在的包名targetProject     指定在该项目下所在的路径|指定生成到的工程名称--><javaModelGenerator targetPackage="com.test.model"targetProject=".\src\main\java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="false"/><!-- 是否对model添加 构造函数 true添加,false不添加--><property name="constructorBased" value="false"/><!-- 是否对类CHAR类型的列的数据进行trim操作 --><property name="trimStrings" value="true"/><!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 --><property name="immutable" value="false"/></javaModelGenerator><!--Mapper映射文件生成所在的目录 为每一个数据库的表生成对应的SqlMapper文件 --><sqlMapGenerator targetPackage="com.test.mapper"targetProject=".\src\main\java"><property name="enableSubPackages" value="false"/></sqlMapGenerator><!-- 客户端代码,生成易于使用的针对Model对象和XML配置文件 的代码type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象type="XMLMAPPER",生成SQLMapper XML文件和独立的Mapper接口--><javaClientGenerator targetPackage="com.test.mapper"targetProject=".\src\main\java" type="XMLMAPPER"><property name="enableSubPackages" value="true"/></javaClientGenerator><!--需要映射的数据库的表名--><table tableName="t_userinfo" domainObjectName="UserInfo"enableCountByExample="false" enableUpdateByExample="false"enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table></context>
</generatorConfiguration>

第二步:新建generator.properties文件

jdbc.driverLocation=C:\\mysql-connector-java-5.1.43.jar
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.connectionURL=jdbc:mysql://localhost:3306/mybatis
jdbc.userId=root
jdbc.password=tiger

第三步:配置执行mybatis generator操作,这里有两种方式

这里有两种方式

第1种方式:如果使用maven项目就可以省去编写Java启动类,使用maven插件和配置文件pom.xml即可,插件启动maven-generator,在pom.xml中添加maven-generator插件

<plugins><!--myBatis逆向工程插件--><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.2</version><configuration><verbose>true</verbose><overwrite>true</overwrite><configurationFile>${project.basedir}/src/main/resources/generatorConfig.xml</configurationFile></configuration><dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.35</version></dependency></dependencies></plugin></plugins>

点击mybatis-generator:generate就能执行mybatis generator了

第2种方式:

①:如果不是maven项目添加该mybatis-generator-core-1.3.2.jar,编写main方法指向mybatis逆向工程,我给依赖粘贴到下面了

<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core -->
<dependency><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-core</artifactId><version>1.3.2</version>
</dependency>

②:修改generatorConfig.xml文件

 <classPathEntry location="${jdbc.driverLocation}"/>

③:然后编写测试类执行:

/*** 如果不是maven项目可以这样生成*/
public class MybatisGeneratorTest {public static void main(String[] args) throws InterruptedException, SQLException, IOException, InvalidConfigurationException, XMLParserException {List<String> warnings = new ArrayList<String>();//生成的java文件是否覆盖boolean overwrite = true;//指定逆向工程配置文件//File configFile = new File("E:\\project\\mybatis-generator\\src\\main\\resources\\generatorConfig.xml");InputStream resourceAsStream = MybatisGeneratorTest.class.getClassLoader().getResourceAsStream("generatorConfig.xml");ConfigurationParser cp = new ConfigurationParser(warnings);Configuration config = cp.parseConfiguration(resourceAsStream);DefaultShellCallback callback = new DefaultShellCallback(overwrite);MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,callback, warnings);myBatisGenerator.generate(null);}
}

数据库表结构:

查看生成的实体类:

TIP:可以看出如果实体类想要遵循驼峰命名规范,数据库表字段名设计需要用"_"来划分

查看生成的文件信息:

TIP1:必须在<plugin></plugin>标签里添加数据库驱动,在其他地方添加无效,如果不添加会报找不到驱动错误,如过不在该插件添加数据库依赖的话可以使用 <classPathEntry location="${jdbc.driverLocation}"/>来指定数据库驱动位置。

TIP2:如果你在使用mybatis generator插件执行的时候报[ERROR] Failed to execute goal org.mybatis.generator:mybatis-generator-maven-plugin:1.3.2:generate (default-cli) on project mybatis-generator: <properties> resource generator.properties does not exist -> [Help 1]

尽管你的<properties resource="generator.properties"></properties>配置的没有问题,但是还是找不到generator.properties,查看该配置,注释掉

该配置会改变generatorConfig.xml中读取generator.properties文件的默认路径

TIP3:Mybatis Generator反向工程默认不会覆盖生成的*.java文件。也可以设置覆盖生成的*.java文件,在反向工程插件mybatis-generator-maven-plugin添加该配置<overwrite>true</overwrite>则会覆盖生成的*.java文件,如图

Mybatis Generator不会覆盖你的mapper.xml文件,他会合并追加到mapper.xml和你自定义的存在一起,但是如果你修改他第一次默认生成的sql(自己生成的CRUD),他会重新把自己生成的CRUD恢复默认,说白了,他只会覆盖他自己生成的,不会覆盖你自定义的,你自定义的不变。。如图,他不会动你的自定义sql,只会覆盖Mybatis反向工程自己生成的sql

更多Mybatis逆向工程的使用参考:http://www.mybatis.org/generator/index.html

Mybatis Generator逆向工程的使用相关推荐

  1. Mybatis Generator 自动生成数据库XML(Mybatis Generator 逆向工程)

    Mybatis Generator 逆向工程自动生成XML 1.MyBatis Generator简单介绍: (1)MyBatis Generator 会生成: Dao,Model,Mapping基础 ...

  2. IDEA 中使用 MyBatis Generator 逆向工程出现运行成功但是没有生成相应的文件

    记录一个 MyBatis Generator 逆向工程出现运行成功但是没有生成相应的文件问题. 我这里使用的是main方法运行,在出现运行成功没有报错但是也没有生成对应的文件,把下面这一段代码加上运行 ...

  3. 在IDEA中使用MyBatis Generator逆向工程生成代码

    本文介绍一下用Maven工具如何生成Mybatis的代码及映射的文件. 一.配置Maven pom.xml 文件 在pom.xml增加以下插件: <build><finalName& ...

  4. mybatis.generator逆向工程生成数据库访问mybatis代码

    1.添加POM依赖 <dependency><groupId>org.mybatis</groupId><artifactId>mybatis</ ...

  5. tkmbatis 日志_springboot+maven+tk.mybatis+generator逆向工程

    1.父工程的pom.xml中导入依赖和插件,当前完整的文件如下: 4.0.0 com.sino demo_parent pom 1.0-SNAPSHOT bos org.springframework ...

  6. MyBatis Generator 逆向工程插件

    原文地址:http://www.yiidian.com/mybatis/mybatis-generator.html 1 MyBatis Gernerator插件概述 官网:http://mybati ...

  7. idea mybatis generator插件_在idea中使用mybatis generator逆向工程生成代码

    用maven工具生成mybatis的代码和映射文件. 1.配置pom.xml文件 在pom.xml下添加插件如下: <build> <finalName>zsxt</fi ...

  8. mybatis generator逆向工程使用

    项目中有大量表格,可以使用mybatis generator来逆向生成代码: 首先在pom文件中引入: <build><plugins><plugin><gr ...

  9. 2019-04-28 Mybatis generator逆向工程生成的Example代码分析

    今天主要对Mybatis generator生成的DAO层等进行分析,讲解Example类的使用和扩展 1.先在数据库建表 1 CREATE TABLE `department` ( 2 `fid` ...

最新文章

  1. 静态初始化块的执行顺序
  2. 为什么德国人工作这么慢,但效率却很高?
  3. spring data jpa update
  4. 那些公司用计算机仪表电缆,计算机及仪表用电缆技术
  5. 编辑距离 在输入检测中的应用
  6. API/POSIX/C库的区别与联系
  7. Elasticsearch 日期时间处理
  8. 日期判断是今天/明天/后天
  9. 保定华电计算机考研真题,华北电力大学(保定)离散数学试题(含2005年真题)...
  10. 南京信息工程大学计算机考研怎么样,南京信息工程大学就业怎么样,考研好不好?...
  11. 计算机专业老师考什么教师,老师!计算机专业的考试也太太太太太太难了!
  12. 无接任何usb设备却提示无法识别usb设备
  13. 计算机专业学习资源合集 | 视频电子书资源
  14. mac下载、破解、安装webstorm编辑器
  15. 大端模式和小端模式是什么意思?
  16. 2022年康复医学治疗技术高级职称考试题库及答案
  17. Unity打开VS,一直显示hold on,一直在加载资源的解决办法
  18. 二叉树、二叉查找树与红黑树的原理及Java实现
  19. 二目运算符是什么意思?
  20. 28岁实现财务自由,网友:打扰了

热门文章

  1. Hi3518EV200+PS3210调试经验总结
  2. HP DL380 G9 配置RAID
  3. uni-app接入高德地图SDK实现定位用户城市
  4. 单机网页游戏的如何修改服务器数据库,页游源码【神创天下】单机版GM修改+人物数据修改教程+一键启动客户端服务端...
  5. Dream to Control Learning Behaviors by Latent Imagination-笔记
  6. 计算机音乐非酋,非酋在线试听_薛明媛_高音质歌曲_九酷音乐
  7. 作为程序员,如何开展自己的副业?月赚三万的真实故事
  8. Verilog 的层次化事件队列+阻塞赋值与非阻塞赋值理解
  9. [SUCTF 2019] SignIn
  10. 阿里巴巴编码规范(Java)