zoukankan      html  css  js  c++  java
  • 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;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;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;88.7pt;">
    		<p style="margin-left:0cm;">CRUD操作</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">代码生成后每个Mapper有固定的CRUD方法;</p>
    
    		<p style="margin-left:0cm;">在每个Mapper上分别扩展</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">提供通用Mapper接口;</p>
    
    		<p style="margin-left:0cm;">可以扩展通用接口</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">提供BaseMapper接口;</p>
    
    		<p style="margin-left:0cm;">可以扩展通用接口</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">条件构造器</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">每个实体类自己的Example构造条件</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">提供通用Example</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">提供Wrapper进行复杂条件构造</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">乐观锁</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">主键策略</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">分页</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">逻辑删除</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">通用枚举</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">攻击Sql阻断</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;108.4pt;">
    		<p style="margin-left:0cm;">支持</p>
    		</td>
    	</tr><tr><td style="vertical-align:top;88.7pt;">
    		<p style="margin-left:0cm;">性能分析</p>
    		</td>
    		<td style="vertical-align:top;110.7pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;107pt;">
    		<p style="margin-left:0cm;">&nbsp;</p>
    		</td>
    		<td style="vertical-align:top;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
  • 相关阅读:
    C#基础视频教程5.3 如何编写简单的超级热键
    spring boot中注入jpa时报could not autowire.No beans of 'PersonRepository' type found
    SpringBoot中常用注解@Controller/@RestController/@RequestMapping的区别
    idea如何搭建springboot框架
    Fiddler建好代理后,能连到手机,但手机不能上网了是什么原因
    如何用Fiddler对Android应用进行抓包
    【fiddler】抓取https数据失败,全部显示“Tunnel to......443”
    将excel的数据导入到数据库后都乱码了是怎么回事
    java保存繁体字到数据库时就报错Incorrect string value: 'xF0xA6x8Dx8BxE5xA4...' for column 'name' at row 1
    将爬取的网页数据保存到数据库时报错不能提交JPA,Caused by: java.sql.SQLException: Incorrect string value: 'xF0x9Fx98xB6 xE2...' for column 'content' at row 1
  • 原文地址:https://www.cnblogs.com/jpfss/p/11236162.html
  • Copyright © 2011-2022 走看看