一、简介
MyBatis-Flex 是一个优雅的 MyBatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。
总而言之,MyBatis-Flex 能够极大地提高我们的开发效率和开发体验,让我们有更多的时间专注于自己的事情。
二、特征
2.1 轻量
除了 MyBatis,没有任何第三方依赖轻依赖、没有任何拦截器,其原理是通过 SqlProvider 的方式实现的轻实现。同时,在执行的过程中,没有任何的 Sql 解析(Parse)轻运行。这带来了几个好处:1. 极高的性能;2. 极易对代码进行跟踪和调试;3. 更高的把控性。
2.2 灵活
支持 Entity 的增删改查、以及分页查询的同时,MyBatis-Flex 提供了 Db + Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。与此同时,MyBatis-Flex 内置的 QueryWrapper^灵活 可以轻易的帮助我们实现 多表查询、链接查询、子查询 等等常见的 SQL 场景。
2.3 强大
支持任意关系型数据库,还可以通过方言持续扩展,同时支持 多(复合)主键、逻辑删除、乐观锁配置、数据脱敏、数据审计、 数据填充 等等功能。
三、对比
3.1 功能对比
MyBatis-Flex 主要是和 MyBatis-Plus
与 Fluent-MyBatis
对比,内容来源其官网、git 或者 网络文章。
-
MyBatis-Plus:老牌的 MyBatis 增强框架,开源于 2016 年。
-
Fluent-MyBatis:阿里云开发的 MyBatis 增强框架(来自于阿里云·云效产品团队)
3.2 性能对比
主要是展示了 MyBatis-Flex 和 Mybaits-Plus 的「性能」对比。
测试方法
-
使用 h2 数据库,在初始化的时候分别为 mybatis-flex 和 mybatis-plus 创建两个不同的数据库, 但是完全一样的数据结构、数据内容和数据量(每个库 2w 条数据)。
-
开始之前先进行预热,之后通过打印时间戳的方式进行对比,谁消耗的时间越少,则性能越高(每次测试 10 轮)。
测试源码: https://gitee.com/mybatis-flex/mybatis-benchmark
测试说明:在以下的所有测试中,有可能因为每个人的电脑性能不同,测试的结果会有所不同。
测试结论: MyBatis-Flex 的查询单条数据的速度,大概是 MyBatis-Plus 的 5 ~ 10+ 倍。
四、支持的数据库类型
MyBatis-Flex 支持的数据库类型,如下表格所示,我们还可以通过自定义方言的方式,持续添加更多的数据库支持。
数据库方言
在某些场景下,比如用户要实现自己的 SQL 生成逻辑时,我们可以通过实现自己的方言达到这个目的,实现方言分为两个步骤:
-
1、编写自己的方言类,实现
IDialect
接口; -
2、通过
DialectFactory.registerDialect()
方法注册自己的方言。
五、功能
5.1 基础功能
-
增、删、改
-
基础查询
-
自动映射
-
关联查询
-
批量操作
-
链式操作
-
QueryWrapper
-
Db + Row
-
Active Record
-
IService
-
SpringBoot 配置文件
-
MyBatisFlexCustomizer
5.2 核心功能
-
@Table 注解
-
@Id 注解
-
@Column 注解
-
逻辑删除
-
乐观锁
-
数据填充
-
数据脱敏
-
数据缓存
-
SQL 审计
-
SQL 打印
-
多数据源
-
数据源加密
-
动态表名
-
事务管理
-
数据权限
-
字段权限
-
字段加密
-
字典回写
-
枚举属性
-
多租户
5.3 其他
-
代码生成器
-
APT 设置
-
KAPT 设置
帮助文档地址:https://mybatis-flex.com/zh/intro/getting-started.html