news 2026/1/30 3:11:13

MyBatis-Flex来了!完爆MyBatis-Plus?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MyBatis-Flex来了!完爆MyBatis-Plus?

Mybatis-Flex 是一个优雅的 Mybatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper^亮点 帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。

总而言之,MyBatis-Flex 能够极大地提高我们的开发效率和开发体验,让我们有更多的时间专注于自己的事情。

官网文档:https://mybatis-flex.com/

01

Mybatis-Flex的有什么特点?

轻量:

除了 MyBatis,没有任何第三方依赖轻依赖、没有任何拦截器,其原理是通过 SqlProvider 的方式实现的轻实现。同时,在执行的过程中,没有任何的 Sql 解析(Parse)轻运行。这带来了几个好处:

1、极高的性能;

2、极易对代码进行跟踪和调试;

3、把控性更高。

如果你近期准备面试跳槽,建议在ddkk.com在线刷题,涵盖 一万+ 道 Java 面试题,几乎覆盖了所有主流技术面试题,还有市面上最全的技术五百套,精品系列教程,免费提供。

灵活:

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

强大:

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

02

Mybatis-Flex和同类框架对比

1)功能对比:

2)性能对比:

这里直接贴测试结果:

  • 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+ 倍。

具体性能对比测试,移步:

https://mybatis-flex.com/zh/intro/benchmark.html

03

Mybatis-Flex支持的数据库类型

MyBatis-Flex 支持的数据库类型,如下表格所示,我们还可以通过自定义方言的方式,持续添加更多的数据库支持。

04

快速开始

第 1 步:创建数据库表

CREATETABLEIFNOTEXISTS`tb_account` ( `id` INTEGER PRIMARY KEY auto_increment, `user_name`VARCHAR(100), `age` INTEGER, `birthday` DATETIME ); INSERTINTO tb_account(id, user_name, age, birthday) VALUES(1, '张三', 18, '2020-01-11'), (2, '李四', 19, '2021-03-21');

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

TIP:可以使用 Spring Initializer 快速初始化一个 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>

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

在 application.yml 中配置数据源:

# DataSource Config spring: datasource: url:jdbc:mysql://localhost:3306/flex_test username:root password:12345678

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

@SpringBootApplication @MapperScan("com.mybatisflex.test.mapper") publicclassMybatisFlexTestApplication{ publicstaticvoidmain(String[] args){ SpringApplication.run(MybatisFlexTestApplication.class, args); } }

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

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

@Data @Table("tb_account") publicclassAccount{ @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 接口:

publicinterfaceAccountMapperextendsBaseMapper<Account> { }

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

https://mybatis-flex.com/zh/others/codegen.html

第 5 步:开始使用

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

importstatic com.mybatisflex.test.entity.table.AccountTableDef.ACCOUNT; @SpringBootTest classMybatisFlexTestApplicationTests{ @Autowired private AccountMapper accountMapper; @Test voidcontextLoads(){ QueryWrapper queryWrapper = QueryWrapper.create() .select() .where(ACCOUNT.AGE.eq(18)); Account account = accountMapper.selectOneByQuery(queryWrapper); System.out.println(account); } }

控制台输出:

Account(id=1, userName=张三, age=18, birthday=Sat Jan 1100:00:00 CST 2020)

以上的 示例 中, ACCOUNT 为 MyBatis-Flex 通过 APT 自动生成,只需通过静态导入即可,无需手动编码。

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

官方网站:https://mybatis-flex.com

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/24 19:25:58

禁止血压飙升:阿里大佬写的Controller太优雅了!

见过几千行代码的 controller吗&#xff1f;我见过。见过全是 try catch 的 controller 吗&#xff0c;我见过。见过全是字段校验的 controller 吗&#xff0c;我见过。见过全是业务代码的 controller 吗&#xff1f;不好意思&#xff0c;我们公司很多业务写在 controller 的。…

作者头像 李华
网站建设 2026/1/29 20:01:35

SpringBoot接口防抖(防重复提交)的一些实现方案

前言作为一名老码农&#xff0c;在开发后端Java业务系统&#xff0c;包括各种管理后台和小程序等。在这些项目中&#xff0c;我设计过单/多租户体系系统&#xff0c;对接过许多开放平台&#xff0c;也搞过消息中心这类较为复杂的应用&#xff0c;但幸运的是&#xff0c;我至今还…

作者头像 李华
网站建设 2026/1/26 7:23:13

如何培养学生学习word的兴趣?

引言&#xff1a;当工具遇见心灵在许多计算机课堂上&#xff0c;Word教学却常常陷入“菜单讲解-功能演示-学生模仿”的机械循环&#xff0c;学生们面对那些看似冰冷的按钮、繁杂的菜单&#xff0c;眼中闪烁的往往不是好奇的火花&#xff0c;而是疲惫的迷茫。如何将Word从“不得…

作者头像 李华
网站建设 2026/1/28 8:26:49

参考文献怎么找:高效查找参考文献的实用方法与技巧

做科研的第一道坎&#xff0c;往往不是做实验&#xff0c;也不是写论文&#xff0c;而是——找文献。 很多新手科研小白会陷入一个怪圈&#xff1a;在知网、Google Scholar 上不断换关键词&#xff0c;结果要么信息过载&#xff0c;要么完全抓不到重点。今天分享几个长期使用的…

作者头像 李华
网站建设 2026/1/29 2:01:32

职场必备!ima知识库+AI,让你的收藏夹变成生产力神器

文章介绍了ima知识库工具&#xff0c;通过AI技术重新定义知识的收集、管理、应用和分享。用户可多渠道收集信息&#xff0c;AI自动整理生成摘要&#xff0c;智能问答辅助决策创作&#xff0c;支持团队协作共享。文章提供了PC端和手机端的使用技巧&#xff0c;帮助用户建立标签体…

作者头像 李华