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

1. Mybatis-generator

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

Mybatis-generator主要完成的工作是依据数据库表创建对应的model、dao、mapping文件,可以通过Maven插件或者mybatis-generator的jar包生成。

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

  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和映射文件的文件夹(踩过的坑)。

插件使用参考 https://blog.csdn.net/pucao_cug/article/details/64499355

 

2. 通用Mapper

首先我们来看一下通用Mapper官方给出的用途

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

通用Mapper是对单表的CRUD操作进行了较为详细的实现,使得开发人员可以随意的按照自己的需求选择通用的方法,同时允许开发人员便捷地对通用Mapper进行扩展。

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

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注入等功能,在博客

https://blog.csdn.net/qq_32867467/article/details/82944674中说的较为详细。

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  星朝  阅读(2891)  评论(1编辑  收藏  举报