Mybatis-generator/通用Mapper/Mybatis-Plus对比

1. Mybatis-generator

MyBatis Generator(MBG)是MyBatis MyBatis 和iBATIS的代码生成器。它为全部版本的MyBatis以及版本2.2.0以后的iBATIS版本生成代码。它将根据数据库表生成可用于访问表的文件。javascript

Mybatis-generator主要完成的工做是依据数据库表建立对应的model、dao、mapping文件,能够经过Maven插件或者mybatis-generator的jar包生成。html

这里介绍Maven插件使用方法:java

  1. 在pom.xml文件中加入mybatis-generator系列插件;
  2. 建立generatorConfig.xml文件,在配置文件中指定数据库链接地址、生成类的存放地址、生成对应表的类名等信息;
  3. 执行mybatis-generator插件,便可生成相应文件;
  4. 此外,mybatis-generator自动生成了example类用于构造复杂的筛选条件,详细用法能够参考 http://www.mybatis.org/generator/generatedobjects/exampleClassUsage.html

Mybatis-generator使用较为简单,生成的DAO类及映射文件中包含基本的CRUD操做。须要注意的是,在一次项目中避免屡次执行mybatis-generator,即应当尽可能在数据库表创建完整而且肯定不会修改以后执行mabatis-generator,不然再次执行会覆盖本来的Model、DAO和映射文件的文件夹(踩过的坑)。git

插件使用参考 http://www.javashuo.com/article/p-ukrcyfwd-nc.htmlgithub

 

2. 通用Mapper

首先咱们来看一下通用Mapper官方给出的用途数据库

正如以前提到的,当数据库字段变化频繁时,使用MBG(mybatis-generator)会带来大量的重构工做,对此,通用Mapper给出的解决办法是:给予开发者一个具有丰富的单表方法而且容易扩展的通用的Mapper。markdown

通用Mapper是对单表的CRUD操做进行了较为详细的实现,使得开发人员能够随意的按照本身的需求选择通用的方法,同时容许开发人员便捷地对通用Mapper进行扩展。mybatis

先看一下通用Mapper在Maven项目中的配置:app

1. 在pom.xml中添加插件配置框架

能够看到,通用Mapper的代码生成其实是使用了MGB,所以通用Mapper的代码生成器只是调用了MGB,而后在这个基础上加入了一些元素来方便开发。

2. 来看一下配置文件generatorConfig.xml

 

与MGB原有的配置文件相比,这里只是多了一个插件的配置,这个插件的做用是:配置生成的Mapper接口都会自动继承这个接口,也就是说,使用通用Mapper生成的mapper接口即便看上去空空如也,但已经具有了大量的对数据库的操做方法。此外,通用 Mapper 专用代码生成器生成的 Model 会在原有基础上增长 @Table,@Id,@Column 等注解,方便自动与数据库字段进行映射。

3. 在 pom.xml 这一级目录的命令行窗口执行 mvn mybatis-generator:generate或者直接在执行mvn插件便可。

4. 通用Mapper一样有Example的设计,与MGB不一样的是,MDB会对每个表生成对应的Example类,而通用Mapper提供了一个统一的Example类,这个类和 MBG 生成的相比,须要本身设置属性名,这个类还额外提供了更多的方法。

 

通用Mapper能够看做是MGB的改进和扩展,必定程度上解决了使用MGB重构的问题。

更多详细的使用能够参考官方文档:https://github.com/abel533/Mapper/wiki

 

 

3. Mybatis-Plus

Mybatis-Plus(如下简称MP)是Mybatis的加强工具(MBG和通用Mapper可当作插件),在Mybatis的基础上增长了不少功能,简化开发,提升效率。

先看看MB在Spring Boot中的引入:

1. 在maven中添加MP启动器

2. 要使用代码生成器还须要添加模板引擎依赖

 

3. pom.xml到这里已经配置完成了,下面进行代码的自动生成。AutoGenerator是MP的代码生成器,经过调用AutoGenerator,进行相应的模板、策略配置能够快速生成Entity、Mapper、Mapper XML、Service、Controller各个模块的代码。

AutoGenerator的使用参考 https://mybatis.plus/guide/generator.html

4. MP将通用的CRUD操做封装进BaseMapper接口,而自动生成的Mapper接口便自动继承了BaseMapper接口。复杂的Sql操做,则可使用QueryWrapper(LambdaQueryWrapper) 和 UpdateWrapper(LambdaUpdateWrapper)进行动态Sql拼接。

5. 此外,MP还支持分页、逻辑删除、通用枚举、Sql注入等功能,在博客

http://www.javashuo.com/article/p-xpcopxfl-bc.html中说的较为详细。

6. 值得一提的是,MP提供了性能分析插件,可以输出每条SQL语句及其执行时间,使用它须要在xml中添加相应的插件信息

而后在config文件中添加插件

与MBG不一样,使用Mybatis-Plus自动生成代码须要编写代码,经过调用AutoAutoGenerator类实现代码生成,从这方面来讲不如使用插件方便。可是它丰富的功能以及只是相对复杂的配置仍是使它领先于MBG以及通用Mapper。

 

三款框架的功能对比

 

Mybatis-generator

通用Mapper

Mybatis-Plus

代码生成器

支持自动生成Model,Mapper,Mapper XML文件

<p style="margin-left:0cm;">生成方式不够灵活;</p>

		<p style="margin-left:0cm;">生成代码功能较为简单</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">支持自动生成Entity,Mapper,Mapper XML文件;</p>

		<p style="margin-left:0cm;">提供通用的Mapper模板,生成方式较灵活;</p>

		<p style="margin-left:0cm;">生成的Model文件包含注释可以很好地与数据库表完成映射</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持自动生成Entity,Mapper,Mapper XML,Service,Controller文件;</p>

		<p style="margin-left:0cm;">提供BaseMapper接口</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">CRUD操做</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">代码生成后每一个Mapper有固定的CRUD方法;</p>

		<p style="margin-left:0cm;">在每一个Mapper上分别扩展</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">提供通用Mapper接口;</p>

		<p style="margin-left:0cm;">能够扩展通用接口</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">提供BaseMapper接口;</p>

		<p style="margin-left:0cm;">能够扩展通用接口</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">条件构造器</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">每一个实体类本身的Example构造条件</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">提供通用Example</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">提供Wrapper进行复杂条件构造</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">乐观锁</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">主键策略</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">分页</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">逻辑删除</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">通用枚举</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">攻击Sql阻断</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr><tr><td style="vertical-align:top;width:88.7pt;">
		<p style="margin-left:0cm;">性能分析</p>
		</td>
		<td style="vertical-align:top;width:110.7pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:107pt;">
		<p style="margin-left:0cm;">&nbsp;</p>
		</td>
		<td style="vertical-align:top;width:108.4pt;">
		<p style="margin-left:0cm;">支持</p>
		</td>
	</tr></tbody></table></div><p style="margin-left:0cm;">&nbsp;</p>

总结一下,通用Mapper是对Mybatis-generator的升级改造,解决了使用Mybatis-generator可能须要大量重构的问题,而且在这个基础上加入了一些新的功能。Mybatis-Plus能够看做是在另外一个方向上对Mybatis的升级改造,不只可以根据数据库表快速生成pojo实体类,还封装了大量CRUD方法,使用Wrapper解决了复杂条件构造等问题,更是根据开发中常见的问题给出了一系列解决方案。

在拥有Maven和Spring boot的开发框架下,MBG、通用Mapper和MP均可以快速地完成安装,相比于MBG和通用Mapper仅须要执行插件就能够完成基本的开发工做,MP可能须要更多的开发工做量。

原文地址:https://blog.csdn.net/m0_37524586/article/details/88351833
posted @ 2019-07-24 10:07  星朝  阅读( ...)  评论( ...编辑  收藏
相关文章
相关标签/搜索