MyBatis-Flex
MyBatis-Flex 是一款基于 MyBatis 增强的轻量级 ORM 框架,旨在简化数据库操作、提升开发效率,同时保持 MyBatis 的灵活性和性能优势。它弥补了 MyBatis 在单表操作、查询构建等方面的繁琐性,同时避免了部分 ORM 框架的重量级特性。
核心特点
-
极简的单表操作
内置大量单表 CRUD 方法(如新增、删除、修改、查询),无需编写 XML 或注解 SQL,直接通过实体类对应的Mapper
接口调用即可。例如:// 根据 ID 查询 User user = userMapper.selectById(1); // 新增 userMapper.insert(user); // 条件更新 userMapper.updateByCondition(UpdateWrapper.create().set(User::getName, "newName").where(User::getId).eq(1) );
-
强大的查询构建器
提供QueryWrapper
类,支持链式调用构建复杂查询条件(无需手写 SQL 片段),支持多表关联、分页、排序等操作。例如:List<User> users = userMapper.selectList(QueryWrapper.create().select(User::getId, User::getName) // 指定查询字段.where(User::getAge).gt(18) // 年龄大于 18.and(User::getStatus).eq(1) // 状态为 1.orderBy(User::getCreateTime, true) // 按创建时间倒序 );
-
零 XML 配置(可选)
无需编写传统 MyBatis 的 XML 映射文件,通过注解或接口方法即可完成映射。同时保留对 XML 的兼容,方便处理复杂 SQL 场景。 -
轻量且高性能
核心代码简洁,无过多冗余逻辑,执行效率接近原生 MyBatis。避免了部分 ORM 框架的“黑盒”操作,SQL 执行过程可追踪。 -
丰富的扩展能力
支持自定义 SQL 拦截器、字段填充(如自动填充创建时间、更新时间)、逻辑删除、多数据源等功能,满足复杂业务需求。
与 MyBatis、MyBatis-Plus 的区别
- 对比 MyBatis:MyBatis-Flex 简化了单表操作和查询条件构建,减少重复代码;而 MyBatis 更侧重 SQL 与代码的分离,适合复杂 SQL 场景。
- 对比 MyBatis-Plus:两者功能类似,但 MyBatis-Flex 设计更轻量,API 风格更简洁,对多表关联查询的支持更灵活,且起步较晚(2022 年左右),吸收了同类框架的经验。
适用场景
- 快速开发中小型项目,减少 SQL 编写工作量;
- 需要灵活控制 SQL 且不想被框架过度约束的场景;
- 从 MyBatis 迁移过来的项目,希望平滑过渡并提升效率。
总之,MyBatis-Flex 是 MyBatis 的“增强工具”,既保留了原生 MyBatis 的灵活性,又通过便捷的 API 降低了日常开发的复杂度,适合追求“简单、高效、可控”的开发者使用。