百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MyBatis-Flex:一个优雅的 MyBatis 增强框架

ccwgpt 2025-02-20 14:45 28 浏览 0 评论

更轻量、更灵活、以及更高的性能。Mybatis-Plus相信大家都在用,但是今天要推荐的是功能更强大的MyBatis-Flex。

简介

MyBatis-Flex 是一个优雅的 MyBatis 增强框架,具有轻量、高性能和灵活的特点。通过 MyBatis-Flex,我们可以轻松连接到各种数据库,并利用其内置的 QueryWrapper 大大减少了编写 SQL 的工作量,同时降低了出错的风险。

特征

1、轻量

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

2、灵活

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

3、强大

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

MyBatis-Flex 和同类框架「功能」对比

MyBatis-Flex 主要是和 MyBatis-PlusFluent-MyBatis 对比,内容来源其官网、git 或者 网络文章,若有错误欢迎纠正。

  • MyBatis-Plus:老牌的 MyBatis 增强框架,开源于 2016 年。
  • Fluent-MyBatis:阿里云开发的 MyBatis 增强框架(来自于阿里云·云效产品团队)

功能或特点

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

?

?

?


MyBatis-Flex 和同类框架「性能」对比

测试方法

使用 h2 数据库,在初始化的时候分别为 mybatis-flex 和 mybatis-plus 创建两个不同的数据库, 但是完全一样的数据结构、数据内容和数据量(每个库 2w 条数据)。

开始之前先进行预热,之后通过打印时间戳的方式进行对比,谁消耗的时间越少,则性能越高(每次测试 10 轮)。

这里直接贴测试结果:

  • 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://gitee.com/mybatis-flex/mybatis-benchmark

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

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

    MyBatis-Flex 支持的数据库类型

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

    数据库

    描述

    mysql

    MySQL 数据库

    mariadb

    MariaDB 数据库

    oracle

    Oracle11g 及以下数据库

    oracle12c

    Oracle12c 及以上数据库

    db2

    DB2 数据库

    H2

    H2 数据库

    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

    优炫数据库

    Doris

    Doris数据库

    Hive SQL

    Hive 数据库

    lealone

    Lealone 数据库

    sinodb

    星瑞格数据库


    MyBatis-Flex 视频系列:
    https://www.bilibili.com/video/BV1yW4y1Z74j

    快速开始

    在开始之前,我们假定您已经:

    • 熟悉 Java 环境配置及其开发
    • 熟悉 关系型 数据库,比如 MySQL
    • 熟悉 Spring Boot 及相关框架
    • 熟悉 Java 构建工具,比如 Maven

    当前章节涉及到的源码已经全部上传到:
    https://gitee.com/Suomm/mybatis-flex-test ,在开始之前, 您也可以先下载到本地,导入到 idea 开发工具后,在继续看文档。

    Hello World 文档

    第 1 步:创建数据库表

    CREATE TABLE IF NOT EXISTS `tb_account`
    (
        `id`        INTEGER PRIMARY KEY auto_increment,
        `user_name` VARCHAR(100),
        `age`       INTEGER,
        `birthday`  DATETIME
    );
    
    INSERT INTO tb_account(id, user_name, age, birthday)
    VALUES (1, '张三', 18, '2020-01-11'),
           (2, '李四', 19, '2021-03-21');

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

    可以使用 Spring Initializer 快速初始化一个 Spring Boot 工程。需要添加的 Maven 主要依赖示例:

    
        
            com.mybatis-flex
            mybatis-flex-spring-boot-starter
            1.8.2
        
        
            com.mysql
            mysql-connector-j
            runtime
        
        
            com.zaxxer
            HikariCP
        
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    注意: 如果您当前使用的是 SpringBoot v3.x 版本,需要把依赖
    mybatis-flex-spring-boot-starter 修改为:
    mybatis-flex-spring-boot3-starter, 如下代码所示:

    
        
            com.mybatis-flex
            mybatis-flex-spring-boot3-starter
            1.8.2
        
        
            com.mysql
            mysql-connector-j
            runtime
        
        
            com.zaxxer
            HikariCP
        
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    第 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")
    public class MybatisFlexTestApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(MybatisFlexTestApplication.class, args);
        }
    
    }

    第 4 步:编写实体类和 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 {
    
    }

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

    第 5 步:开始使用

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

    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);
        }
    
    }

    控制台输出:

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

    添删改简单使用

    新增数据

    INSERT INTO `tb_account`(`user_name`, `birthday`) VALUES ("michael", now())

    @Test
    public void testInsertWithRaw() {
        Account account = new Account();
        account.setUserName("michael");
    
        Account newAccount = UpdateWrapper.of(account)
            .setRaw(Account::getBirthday, "now()")
            .toEntity();
    
        accountMapper.insert(newAccount);
    }

    删除数据

    DELETE FROM `tb_account` WHERE id=100;

    QueryWrapper queryWrapper = QueryWrapper.create();
    queryWrapper.where(ACCOUNT.ID.ge(100));
    
    accountMapper.deleteByQuery(queryWrapper);

    部分字段更新

    update tb_account set user_name = null, age = 10 where id =100

    Account account = UpdateEntity.of(Account.class, 100);
    
    account.setUserName(null);
    account.setAge(10);
    
    accountMapper.update(account);

    更多复杂的功能,详见官方网站:https://mybatis-flex.com/

    总结

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

    往期回顾:

    mayfly-go:一个web版linux、数据库、redis、mongo管理操作平台

    领导:谁再用 Redis 实现过期订单关闭,立马滚蛋!

    相关推荐

    自己动手写Android数据库框架_android开发数据库搭建

    http://blog.csdn.net/feiduclear_up/article/details/50557590推荐理由关于Android数据库操作,由于每次都要自己写数据库操作,每次还得去...

    谷歌开源大模型评测工具LMEval,打通谷歌、OpenAI、Anthropic

    智东西编译|金碧辉编辑|程茜智东西5月28日消息,据科技媒体TheDecoder5月26日报道,当天,谷歌正式发布开源大模型评测框架LMEval,支持对GPT-4o、Claude3.7...

    工信部:着力推动大模型算法、框架等基础性原创性的技术突破

    工信部新闻发言人今日在发布会上表示,下一步,我们将坚持突出重点领域,大力推动制造业数字化转型,推动人工智能创新应用。主要从以下四个方面着力。一是夯实人工智能技术底座。通过科技创新重大项目,着力推动大模...

    乒乓反复纠结“框架不稳定”的三个小误区

    很多球友由于对框架的认知不清晰,往往会把“框架不稳定”当成一种心理负担,从而影响学球进度,其典型状态就是训练中有模有样,一旦进入实战,就像被捆住了手脚。通过训练和学习,结合“基本功打卡群”球友们交流发...

    前AMD、英特尔显卡架构师Raja再战GPU,号称要全面重构堆栈

    IT之家8月5日消息,知名GPU架构师拉贾科杜里(RajaKoduri)此前曾先后在AMD和英特尔的显卡部门担任要职。而在今日,由Raja创立的GPU软件与IP初创企...

    三种必须掌握的嵌入式开发程序架构

    前言在嵌入式软件开发,包括单片机开发中,软件架构对于开发人员是一个必须认真考虑的问题。软件架构对于系统整体的稳定性和可靠性是非常重要的,一个合适的软件架构不仅结构清晰,并且便于开发。我相...

    怪不得别人3秒就知道软考案例怎么做能50+

    软考高级统一合格标准必须三科都达到45分,案例分析也一直是考生头疼的一门,但是掌握到得分点,案例能不能50+还不是你们说了算吗?今天就结合架构案例考点,分享实用的备考攻略~一、吃透考点,搭建知识框架从...

    UML统一建模常用图有哪些,各自的作用是什么?一篇文章彻底讲透

    10万+爆款解析:9大UML图实战案例,小白也能秒懂!为什么需要UML?UML(统一建模语言)是软件开发的“蓝图”,用图形化语言描述系统结构、行为和交互,让复杂需求一目了然。它能:降低沟通成本避...

    勒索软件转向云原生架构,直指备份基础设施

    勒索软件组织和其他网络犯罪分子正越来越多地将目标对准基于云的备份系统,对久已确立的灾难恢复方法构成了挑战。谷歌安全研究人员在一份关于云安全威胁演变的报告中警告称,随着攻击者不断改进数据窃取、身份泄露和...

    ConceptDraw DIAGRAM:释放创意,绘就高效办公新未来

    在当今数字化时代,可视化工具已成为提升工作效率和激发创意的关键。ConceptDrawDIAGRAM,作为一款世界顶级的商业绘图软件,凭借其强大的功能和用户友好的界面,正逐渐成为众多专业人士的首选绘...

    APP 制作界面设计教程:一步到位_app界面设计模板一套

    想让APP界面设计高效落地,无需繁琐流程,掌握“框架搭建—细节填充—体验优化”三步法,即可一步到位完成专业级设计。黄金框架搭建是基础。采用“三三制布局”:将屏幕横向三等分,纵向保留三...

    MCP 的工作原理:关键组件_mcp部件

    以下是MCP架构的关键组件:MCP主机:像ClaudeDesktop、GitHubCopilot或旅行助手这样的AI智能体,它们希望通过MCP协议访问工具、资源等。MCP主机会...

    软件架构_软件架构师工资一般多少

    软件架构师自身需要是程序员,并且必须一直坚持做一线程序员。软件架构应该是能力最强的一群程序员,他们通常会在自身承接编程任务的同时,逐渐引导整个团队向一个能够最大化生产力的系统设计方向前进。软件系统的架...

    不知不觉将手机字体调大!老花眼是因为“老了吗”?

    现在不管是联系、交友,还是购物,都离不开手机。中老年人使用手机的时间也在逐渐加长,刷抖音、看短视频、发朋友圈……看手机的同时,人们也不得不面对“视力危机”——老花眼,习惯眯眼看、凑近看、瞪眼看,不少人...

    8000通用汉字学习系列讲座(第046讲)

    [表声母字]加(续)[从声汉字]伽茄泇迦枷痂袈笳嘉驾架咖贺瘸(计14字)嘉[正音]标准音读jiā。[辨形]上下结构,十四画。会意形声字,从壴从加,加也表声。注:从壴,字义与鼓乐有关;从加,字义与...

    取消回复欢迎 发表评论: