简介
MyBatis-Flex 是一个优雅的 MyBatis 增强框架,它非常轻量、同时拥有极高的性能与灵活性。我们可以轻松的使用 Mybaits-Flex 链接任何数据库,其内置的 QueryWrapper帮助我们极大的减少了 SQL 编写的工作的同时,减少出错的可能性。
总而言之,MyBatis-Flex 能够极大地提高我们的开发效率和开发体验,让我们有更多的时间专注于自己的事情。

特征
-
更轻量
除了 MyBatis,没有任何第三方依赖轻依赖、没有任何拦截器,其原理是通过 SqlProvider 的方式实现的轻实现。同时,在执行的过程中,没有任何的 Sql 解析(Parse)轻运行。 这带来了几个好处:1、极高的性能;2、极易对代码进行跟踪和调试; 3、更高的把控性。
-
更灵活
支持 Entity 的增删改查、以及分页查询的同时,MyBatis-Flex 提供了 Db + Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。 与此同时,MyBatis-Flex 内置的 QueryWrapper^灵活 可以轻易的帮助我们实现 多表查询、链接查询、子查询 等等常见的 SQL 场景。
-
更强大
支持任意关系型数据库,还可以通过方言持续扩展,同时支持 多(复合)主键、逻辑删除、乐观锁配置、数据脱敏、数据审计、 数据填充 等等功能。
MyBatis-Flex 和同类框架
功能或特点 |
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 支持的数据库类型
数据库 |
描述 |
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 |
星瑞格数据库 |
快速开始
第 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 依赖
评论