项目特征
- 轻量,框架只依赖 Mybatis 再无其他第三方依赖
- 只增强,支持 Entity 的增删改查及分页查询
- 内置 Db Row 工具,可以无需实体类进行增删改查
- 几乎支持市面上所有的数据库,还可以通过方言持续扩展
- 支持多(联合)主键,以及不同的主键内容生成策略
- 支持逻辑删除设置、更新或插入的默认值配置
- 支持数据脱敏和字段脱敏
- 支持字典回写,将数据库中的枚举值转换为页面显示的名称
- 支持多租户
- MyBatis-Flex 速度大概是 MyBatis-Plus 的 5 ~ 10 倍
使用案例
定义mapper
代码语言:javascript复制public interface UserMapper extends BaseMapper<User> {
}
代码语言:javascript复制//普通查询
QueryWrapper queryWrapper = QueryWrapper.create()
.select()
.where(User.AGE.eq(18));
Account account = userMapper.selectOneByQuery(queryWrapper);
在数据量大的情况使用游标查询
代码语言:javascript复制Db.tx(() -> {
Cursor<User> userList = userMapper.selectCursorByQuery(query);
for (User user : userList) {
//todo 业务处理
}
return true;
});
在每次for循环时候才去查询数据,不是一次性把数据都读出来,适合批量处理数据的场景,比如对账、加载到缓存,导出数据等等。
数据缓存
在 Spring Boot 配置类上启用 Spring Cache 缓存
代码语言:javascript复制@EnableCaching
@Configuration
public class CacheConfig {
}
ServiceImpl继承 CacheableServiceImpl 实现类
代码语言:javascript复制@Service
@CacheConfig(cacheNames = "user")
public class UserServiceImpl extends CacheableServiceImpl<UserMapper, Account> implements UserService {
// 根据主键缓存数据
@Override
@Cacheable(key = "#id")
public User getById(Serializable id) {
return super.getById(id);
}
// 根据方法名加查询 SQL 语句缓存结果数据
// 加上方法名是为了避免不同的方法使用一样的 QueryWrapper
@Override
@Cacheable(key = "#root.methodName ':' #query.toSQL()")
public List<User> list(QueryWrapper query) {
return super.list(query);
}
}
其他增删改查方法可以参考官方文档。
项目地址
代码语言:javascript复制https://github.com/mybatis-flex/mybatis-flex
总结
mybatis-flex是Mybatis的增强版,几乎集成了mybatis plus、jooq、fluent mybatis的所有优点,大家可以探索一下。