MyBatis-Flex 和MyBatis-Plus Fluent-MyBatis 比较

MyBatis-Flex是一个高性能的MyBatis增强框架,强调轻量级和灵活的特性。它支持多种数据库,提供QueryWrapper简化SQL编写,且在不进行SQL解析的情况下保证高性能。相比MyBatis-Plus和Fluent-MyBatis,MyBatis-Flex具有更低的依赖性和更强的灵活性,包括对多表查询、逻辑删除、乐观锁等功能的支持。
摘要由CSDN通过智能技术生成

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

        MyBatis-Flex 主要是和 MyBatis-Plus 与 Fluent-MyBatis 对比,内容来源其官网、git 或者 网络文章

特征

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

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

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

功能对比

功能或特点MyBatis-FlexMyBatis-PlusFluent-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 和 Mybaits-Plus 的「性能」对比。Mybaits-Plus 是一个非常优秀 Mybaits 增强框架, 其开源于 2016 年,有很多的成功案例

MyBatis-Flex 支持的数据库类型

数据库描述
mysqlMySQL 数据库
mariadbMariaDB 数据库
oracleOracle11g 及以下数据库
oracle12cOracle12c 及以上数据库
db2DB2 数据库
hsqlHSQL 数据库
sqliteSQLite 数据库
postgresqlPostgreSQL 数据库
sqlserver2005SQLServer2005 数据库
sqlserverSQLServer 数据库
dm达梦数据库
xugu虚谷数据库
kingbasees人大金仓数据库
phoenixPhoenix HBase 数据库
gaussGauss 数据库
clickhouseClickHouse 数据库
gbase南大通用(华库)数据库
gbase-8s南大通用数据库 GBase 8s
oscar神通数据库
sybaseSybase ASE 数据库
OceanBaseOceanBase 数据库
FirebirdFirebird 数据库
derbyDerby 数据库
highgo瀚高数据库
cubridCUBRID 数据库
goldilocksGOLDILOCKS 数据库
csiidbCSIIDB 数据库
hanaSAP_HANA 数据库
impalaImpala 数据库
verticaVertica 数据库
xcloud行云数据库
redshift亚马逊 redshift 数据库
openGauss华为 openGauss 数据库
TDengineTDengine 数据库
informixInformix 数据库
greenplumGreenplum 数据库
uxdb优炫数据库

测试源码: mybatis-benchmark: Mybatis-Flex 和 Mybatis-Plus 的性能对比

参考:

MyBatis-Flex - MyBatis-Flex 官方网站 

MyBatis-Flex 是什么 - MyBatis-Flex 官方网站

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FluentMybatis中,可以通过Java API构造复杂的业务SQL语句,实现代码逻辑和SQL逻辑的合一,而无需编写具体的XML文件。这样可以减少在DAO中组装查询或更新操作的工作,也不需要在XML或Mapper中再组装参数。相比于原生MybatisMybatis Plus或其他框架,FluentMybatis提供了以下便利: 1. 通过Java API构造SQL语句:FluentMybatis提供了一套简洁的API,可以通过链式调用的方式构建SQL语句,使得代码更加清晰和易于维护。 2. 无需编写XML文件:FluentMybatis不需要编写繁琐的XML文件,可以直接在Java代码中定义实体类和表结构的映射关系,简化了开发过程。 3. 支持复杂的查询操作:FluentMybatis支持多表关联查询、子查询、分页查询等复杂的查询操作,可以满足各种业务需求。 4. 提供了灵活的参数传递方式:FluentMybatis支持使用注解或者占位符的方式传递参数,可以根据具体的需求选择合适的方式。 在使用FluentMybatis进行模糊查询时,可以使用`like`关键字和通配符来实现。例如,可以使用`like`关键字和`%`通配符来进行前缀、后缀或者中间模糊查询。具体的使用方式可以参考FluentMybatis的文档或者示例代码。 #### 引用[.reference_title] - *1* [Fluent Mybatis、原生Mybatis,、Mybatis Plus 大对比,哪个更好用?](https://blog.csdn.net/j3T9Z7H/article/details/126736632)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Mybatis--2](https://blog.csdn.net/sunshinemen123/article/details/122013025)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值