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

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

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/m0_37524586/article/details/88351833
            </div>
                                                <!--一个博主专栏付费入口-->
         
         <!--一个博主专栏付费入口结束-->
        <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-4a3473df85.css">
                                    <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-4a3473df85.css">
            <div class="htmledit_views" id="content_views">
                                        <h1><a name="t0"></a>1. Mybatis-generator</h1>

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。

 

三款框架的功能对比

在这里插入图片描述

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

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

文章最后发布于: 2019-03-08 15:20:10

本文转载自 : https://blog.csdn.net/m0_37524586/article/details/88351833

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值