天天看点

持久层增强框架Mybatis-Flex

作者:王之于水

一、Mybatis-Flex是什么?

Mybatis-Flex 是一个优雅的 Mybatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper^亮点 帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。总而言之,MyBatis-Flex 能够极大地提高我们的开发效率和开发体验,让我们有更多的时间专注于自己的事情。

二、Mybatis-Flex的有什么特点?

1、轻量: 除了 MyBatis,没有任何第三方依赖轻依赖、没有任何拦截器,其原理是通过 SqlProvider 的方式实现的轻实现。同时,在执行的过程中,没有任何的 Sql 解析(Parse)轻运行。这带来了几个好处:1、极高的性能;2、极易对代码进行跟踪和调试;3、把控性更高。

2、灵活: 支持 Entity 的增删改查、以及分页查询的同时,Mybatis-Flex 提供了 Db + Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。与此同时,Mybatis-Flex 内置的 QueryWrapper^灵活 可以轻易的帮助我们实现 多表查询、链接查询、子查询 等等常见的 SQL 场景。

3、强大: 支持任意关系型数据库,还可以通过方言持续扩展,同时支持 多(复合)主键、逻辑删除、乐观锁配置、数据脱敏、数据审计、 数据填充 等等功能。

三、Mybatis-Flex功能

对 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 的查询单条数据的速度,大概是 MyBatis-Plus 的 5 ~ 10+ 倍。

MyBatis-Flex 的查询 10 条数据的速度,大概是 MyBatis-Plus 的 5~10 倍左右。

Mybatis-Flex 的分页查询速度,大概是 Mybatis-Plus 的 5~10 倍左右。

Mybatis-Flex 的数据更新速度,大概是 Mybatis-Plus 的 5~10+ 倍。

四、Mybatis-Flex搭建

第1步:创建 Spring Boot 项目,并添加 Maven 依赖

<dependencies>

<dependency>

<groupId>com.mybatis-flex</groupId>

<artifactId>mybatis-flex-spring-boot-starter</artifactId>

<version>1.5.3</version>

</dependency>

<dependency>

<groupId>com.mysql</groupId>

<artifactId>mysql-connector-j</artifactId>

<scope>runtime</scope>

</dependency>

<dependency>

<groupId>com.zaxxer</groupId>

<artifactId>HikariCP</artifactId>

</dependency>

<!-- for test only -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-test</artifactId>

<scope>test</scope>

</dependency>

</dependencies>

第 2 步:对 Spring Boot 项目进行配置

在 application.yml 中配置数据源:

spring:

datasource:

url: jdbc:mysql://localhost:3306/datebasename

username: root

password: root

在 Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹:

第3 步:编写实体类和 Mapper 接口

这里使用了 Lombok 来简化代码。

@Data

@Table("tb_account")

public class Account {

@Id(keyType = KeyType.Auto)

private Long id;

private String userName;

private Integer age;

private Date birthday;

}

  • 使用 @Table("tb_account") 设置实体类与表名的映射关系
  • 使用 @Id(keyType = KeyType.Auto) 标识主键为自增

Mapper 接口继承 BaseMapper 接口:

public interface AccountMapper extends BaseMapper<Account> {

}

这部分也可以使用 MyBatis-Flex 的代码生成器来生,功能非常强大的

第 4步:开始使用

添加测试类,进行功能测试:

import static com.mybatisflex.test.entity.table.AccountTableDef.ACCOUNT;

@SpringBootTest

class MybatisFlexTestApplicationTests {

@Autowired

private AccountMapper accountMapper;

@Test

void contextLoads() {

QueryWrapper queryWrapper = QueryWrapper.create()

.select()

.where(ACCOUNT.AGE.eq(18));

Account account = accountMapper.selectOneByQuery(queryWrapper);

System.out.println(account);

}

}

整体来讲,这个框架是Mybatis的增强版,几乎集成了mybatis plus、jooq、fluent mybatis的所有优点,大家可以探索一番