news 2026/5/26 6:09:54

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

作者头像

张小明

前端开发工程师

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

因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享

点击关注#互联网架构师公众号,领取架构师全套资料 都在这里

0、2T架构师学习资料干货分

上一篇:2T架构师学习资料干货分享

大家好,我是互联网架构师!

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

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

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

Mybatis-Flex的有什么特点?

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

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

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

Mybatis-Flex和同类框架对比

1)功能对比:

功能或特点

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

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

Mybatis-Flex支持的数据库类型

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

数据库

描述

mysql

MySQL 数据库

mariadb

MariaDB 数据库

oracle

Oracle11g 及以下数据库

oracle12c

Oracle12c 及以上数据库

db2

DB2 数据库

hsql

HSQL 数据库

sqlite

SQLite 数据库

postgresql

PostgreSQL 数据库

sqlserver2005

SQLServer2005 数据库

sqlserver

SQLServer 数据库

dm

达梦数据库

xugu

虚谷数据库

kingbasees

人大金仓数据库

phoenix

Phoenix HBase 数据库

gauss

Gauss 数据库

clickhouse

ClickHouse 数据库

gbase

南大通用(华库)数据库

gbase-8s

南大通用数据库 GBase 8s

oscar

神通数据库

sybase

Sybase ASE 数据库

OceanBase

OceanBase 数据库

Firebird

Firebird 数据库

derby

Derby 数据库

highgo

瀚高数据库

cubrid

CUBRID 数据库

goldilocks

GOLDILOCKS 数据库

csiidb

CSIIDB 数据库

hana

SAP_HANA 数据库

impala

Impala 数据库

vertica

Vertica 数据库

xcloud

行云数据库

redshift

亚马逊 redshift 数据库

openGauss

华为 openGauss 数据库

TDengine

TDengine 数据库

informix

Informix 数据库

greenplum

Greenplum 数据库

uxdb

优炫数据库

快速开始

第 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/

认说到底,程序从职场角度看,公司这样做很可能是想“信息差”捞点回本。建议保存所有当年的交接记录、邮件、IM聊天截图,必要时走仲裁流程,不然这种事开了先例,下一个就可能是别人员写代码要留注释,职场上做事也要留痕迹。只有手里握着证据,才能不被随便背锅。,

1、2T架构师学习资料干货分享

2、10000+TB资源,阿里云盘,牛逼!!

3、基本涵盖了Spring所有核心知识点总结

· END ·

最后,关注公众号互联网架构师,在后台回复:2T,可以获取我整理的 Java 系列面试题和答案,非常齐全。

如果这篇文章对您有所帮助,或者有所启发的话,帮忙扫描上方二维码关注一下,您的支持是我坚持写作最大的动力。

求一键三连点赞、转发、在看

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

物联网平台二开

物联网平台 - Thinglinks-iot ## &#x1f31f; 项目简介 一个功能完备、高可扩展的物联网平台&#xff0c;提供完整的设备接入、管理和数据处理解决方案。支持多种网络协议&#xff0c;具备强大的消息解析和实时告警能力&#xff0c;帮助企业快速构建物联网应用。 该项目现已纳…

作者头像 李华
网站建设 2026/5/25 15:32:40

基于springboot和vue的厨房菜谱美食分享网站的设计与实现

目录已开发项目效果实现截图开发技术系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&…

作者头像 李华
网站建设 2026/5/26 3:27:43

Android设备日志分析与电源管理问题

这份日志显示了一个Android设备从唤醒&#xff08;Resume&#xff09;到再次休眠&#xff08;Suspend&#xff09; 的完整过程&#xff0c;其中出现了两个关键错误&#xff1a; 主要问题分析&#xff1a; 1. MSDC/eMMC通信失败&#xff08;核心问题&#xff09; [149013.510436…

作者头像 李华
网站建设 2026/5/26 3:22:19

【dz-982】基于单片机的篮球计分器

摘 要 随着体育赛事的不断发展&#xff0c;篮球比赛的计分和记录方式逐渐向自动化、智能化方向发展。传统的计分方式存在人工操作繁琐、容易出错等问题&#xff0c;因此开发一种高效、准确的篮球比赛自动积分设备具有重要的现实意义。 本设计旨在通过现代电子技术和物联网技…

作者头像 李华
网站建设 2026/5/25 6:57:46

如何利用动环监控系统提升数据中心的能效与安全性?

随着数据中心需求的不断增加&#xff0c;动力环境监控系统成为了提升能效和安全性的关键工具。该系统通过实时监测各种环境因素&#xff0c;如温湿度、电能消耗及设备运行状态&#xff0c;帮助运维人员有效掌握数据中心的健康状况。运维团队可以根据系统提供的数据&#xff0c;…

作者头像 李华
网站建设 2026/5/25 16:06:13

MobaXterm高效运维实战:Linux运维高级技巧与自动化脚本万字详解

第一章&#xff1a;MobaXterm核心优势与架构解析1.1 为什么选择MobaXterm进行Linux运维&#xff1f;MobaXterm作为Windows平台下最强大的远程计算工具箱&#xff0c;为Linux运维工程师提供了无可比拟的便利性&#xff1a;核心优势对比&#xff1a;一体化集成&#xff1a;SSH、X…

作者头像 李华