Mybatis Plus还没学会,又出了一个Mybatis Flex
近日,无意间看到有人在说Mybatis Flex
。,目前较为流行的Mybatis
衍生品有MyBatis-Plus
和Fluent-MyBatis
,Mybatis Flex
是啥玩意儿?然后就百度了解一下。哎,这Mybatis Plus
还没玩明白,Mybatis Flex
又来了,真的卷不动啊。
MyBatis-Flex 是一个优雅的 MyBatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper^亮点 帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。
总而言之,MyBatis-Flex 能够极大地提高我们的开发效率和开发体验,让我们有更多的时间专注于自己的事情。
特征
1、轻量:除了 MyBatis,没有任何第三方依赖轻依赖、没有任何拦截器,其原理是通过 SqlProvider 的方式实现的轻实现。同时,在执行的过程中,没有任何的 Sql 解析(Parse)轻运行。 这带来了几个好处:1、极高的性能;2、极易对代码进行跟踪和调试; 3、把控性更高。
2、灵活:支持 Entity 的增删改查、以及分页查询的同时,MyBatis-Flex 提供了 Db + Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。 与此同时,MyBatis-Flex 内置的 QueryWrapper^灵活 可以轻易的帮助我们实现 多表查询、链接查询、子查询 等等常见的 SQL 场景。
3、强大:支持任意关系型数据库,还可以通过方言持续扩展,同时支持 多(复合)主键、逻辑删除、乐观锁配置、数据脱敏、数据审计、 数据填充 等等功能。
MyBatis-Flex 和同类框架「功能」对比
功能对比
功能或特点 | MyBatis-Flex | MyBatis-Plus | Fluent-MyBatis |
---|---|---|---|
对 entity 的基本增删改查 | ✅ | ✅ | ✅ |
分页查询 | ✅ | ✅ | ✅ |
分页查询之总量缓存 | ✅ | ✅ | ❌ |
分页查询无 SQL 解析设计(更轻量,及更高性能) | ✅ | ❌ | ✅ |
多表查询: from 多张表 | ✅ | ❌ | ❌ |
多表查询: left join、inner join 等等 | ✅ | ❌ | ✅ |
多表查询: union,union all | ✅ | ❌ | ✅ |
单主键配置 | ✅ | ✅ | ✅ |
多种 id 生成策略 | ✅ | ✅ | ✅ |
支持多主键、复合主键 | ✅ | ❌ | ❌ |
字段的 typeHandler 配置 | ✅ | ✅ | ✅ |
除了 MyBatis,无其他第三方依赖(更轻量) | ✅ | ❌ | ❌ |
QueryWrapper 是否支持在微服务项目下进行 RPC 传输 | ✅ | ❌ | 未知 |
逻辑删除 | ✅ | ✅ | ✅ |
乐观锁 | ✅ | ✅ | ✅ |
SQL 审计 | ✅ | ❌ | ❌ |
数据填充 | ✅ | ✅ | ✅ |
数据脱敏 | ✅ | ✔️ | (收费) |
字段权限 | ✅ | ✔️ | (收费) |
字段加密 | ✅ | ✔️ | (收费) |
字典回写 | ✅ | ✔️ | (收费) |
Db + Row | ✅ | ❌ | ❌ |
Entity 监听 | ✅ | ❌ | ❌ |
多数据源支持 | ✅ | 借助其他框架或收费 | ❌ |
多数据源是否支持 Spring 的事务管理,比如 @Transactional 和 TransactionTemplate 等 | ✅ | ❌ | ❌ |
多数据源是否支持 “非Spring” 项目 | ✅ | ❌ | ❌ |
多租户 | ✅ | ✅ | ❌ |
动态表名 | ✅ | ✅ | ❌ |
动态 Schema | ✅ | ❌ | ❌ |
以上内容来自第三方相关产品的官方文档或第三方平台,若有错误,欢迎纠正。
基础查询
MyBatis-Flex:
1 | QueryWrapper query = QueryWrapper.create() |
MyBatis-Plus:
1 | QueryWrapper<Employee> queryWrapper = Wrappers.query() |
或者 MyBatis-Plus 的 lambda 写法:
1 | LambdaQueryWrapper<Employee> queryWrapper = Wrappers.<Employee>lambdaQuery() |
Fluent-MyBatis:
1 | EmployeeQuery query = new EmployeeQuery() |
查询集合函数
MyBatis-Flex:
1 | QueryWrapper query = QueryWrapper.create() |
MyBatis-Plus:
1 | QueryWrapper<Employee> queryWrapper = Wrappers.query() |
缺点:字段硬编码,容易拼错。无法使用 ide 的字段进行重构,无法使用 IDE 自动提示,发生错误不能及时发现。
Fluent-MyBatis:
1 | EmployeeQuery query = new EmployeeQuery() |
缺点:编写内容不符合 sql 直觉。
and(…) 和 or(…)
假设我们要构建如下的 SQL 进行查询(需要在 SQL 中添加括号)。
1 | SELECT * FROM tb_account |
MyBatis-Flex:
1 | QueryWrapper query = QueryWrapper.create() |
MyBatis-Plus:
1 | QueryWrapper<Employee> query = Wrappers.query() |
Fluent-MyBatis:
1 | AccountQuery query = new AccountQuery() |
缺点:许多 .end() 方法调用,容易忘记出错(或者写错了?欢迎纠正)。
多表查询 1
MyBatis-Flex:
1 | QueryWrapper query = QueryWrapper.create() |
MyBatis-Plus:
// 不支持~~~~
Fluent-MyBatis:
1 | StudentQuery leftQuery = new StudentQuery("a1").selectAll() |
缺点:编写内容不符合 sql 直觉。同时在编写 end() 和 endJoin() 容易忘记。
多表查询 2
假设查询的 SQL 如下:
1 | SELECT a.id, a.user_name, b.id AS articleId, b.title |
MyBatis-Flex:
1 | QueryWrapper query = new QueryWrapper() |
MyBatis-Plus:
// 不支持~~~~
Fluent-MyBatis:
// 不支持~~~~
PS:也有可能是笔者自己不知道如何支持,而非 Fluent-MyBatis 原因,有知道的同学可以给下示例代码。
部分字段更新
假设一个实体类 Account 中,我们要更新其内容如下:
. userName 为 “michael”
. age 为 “18”
. birthday 为 null
其他字段保持数据库原有内容不变,要求执行的 SQL 如下:
1 | update tb_account |
MyBatis-Flex 代码如下:
1 | Account account = UpdateEntity.of(Account.class); |
MyBatis-Plus 代码如下(或可使用 MyBatis-Plus 的 LambdaUpdateWrapper,但性能没有 UpdateWrapper 好):
1 | UpdateWrapper<Account> updateWrapper = new UpdateWrapper<>(); |
Fluent-MyBatis 代码如下:
1 | AccountUpdate update = new AccountUpdate() |
从功能上来看,Mybatis Flex
确实比MyBatis-Plus
和Fluent-MyBatis
要多尔全,但是它毕竟今年年初才开始开源的新事物,暂时,我处于学习、观望的态度。有时候功能也不是越多越好,适合自己的才是最好的。
Mybatis Plus还没学会,又出了一个Mybatis Flex