0

0

2026 最好用的 ORM 框架:xbatis 1.9.7 正式发布,基于 mybatis 的 ORM 框架

心靈之曲

心靈之曲

发布时间:2026-01-20 19:16:07

|

932人浏览过

|

来源于php中文网

原创

1.9.7 版本更新日志

  • 1:VO 字段注解现支持通过 set 方法上的注解覆盖默认行为
  • 2:数据库类型适配能力增强,新增对自定义 DbType 的全面支持
  • 3:getById 方法扩展,新增 getOptionalById 方法,返回 Optional 类型结果
  • 4:QueryChain 新增 Optional 相关方法,与 get() 方法形成配套支持
  • 5:内置 UUIDv7 主键生成策略,满足高性能、时序安全的主键需求

1.8.7 版本更新日志:

1:为提升 java 与 xml 协同开发体验,querywhere 模块新增 tableas(实体类, 别名) 方法,支持灵活指定表别名

2:配置类 XbatisConfig 已重命名为 XbatisGlobalConfig,语义更清晰、结构更统一

3:新增逻辑删除全局拦截器,开箱即用,无需手动编写删除标记逻辑

4:updatedelete 操作支持原生 RETURNING 子句(数据库原生语法),直接获取变更数据

5:新增原生 SQL 查询接口,并同步支持 update/delete RETURNING 功能

6:引入通用 Mapper 方法拦截器机制,便于统一处理执行前/后逻辑

7:简化 exists / not exists 场景写法,提供更直观的链式调用支持

MagicArena
MagicArena

字节跳动推出的视觉大模型对战平台

下载

通用 SQL 扩展能力:

// 支持任意类型:实体类、VO 或普通 POJO  
SysUser user = sysUserMapper.select(SysUser.class, "select * from t_sys_user where id =?", 1);  

// 支持增删改操作,并可返回指定字段值(如更新后的新用户名)
String user_name = sysUserMapper.executeAndReturning(String.class, "update t_sys_user set user_name=? where id=1 RETURNING user_name", "xxx");

// ORM 风格:删除并返回被删记录(基于数据库原生 RETURNING)
List list = DeleteChain.of(sysUserMapper)
.in(SysUser::getId, 1, 2)
.returning(SysUser.class)
.returnType(SysUser.class)
.executeAndReturningList();

// ORM 风格:更新并返回更新后的完整对象(适用于金额加减等需确认结果场景)
SysUser sysUser = UpdateChain.of(sysUserMapper)
.eq(SysUser::getId, 1)
.set(SysUser::getUserName, "abc2")
.returning(SysUser.class)
.returnType(SysUser.class)
.executeAndReturning();

分表配置示例:

@Data
@SplitTable(SysUserSplitter.class)
public class SysUser {
@TableId
private Integer id;
@SplitTableKey
private Integer groupId;
private String nickname;
private String username;
}
public class SysUserSplitter implements TableSplitter {
@Override
public boolean support(Class type) {
return type == Integer.class || type == int.class;
}

@Override  
public String split(String sourceTableName, Object splitValue) {  
    Integer groupId = (Integer) splitValue;  
    // 按 groupId 取模分 10 张子表  
    return sourceTableName + "_" + (groupId % 10);  
}  

}

分表逻辑简洁明了,其余 CRUD 操作完全透明,与单表无异!!!

1.7.7 版本更新日志:

  • 1:QueryChainDeleteChainInsertChainUpdateChain 全面兼容 BasicMapper 接口方法
  • 2:正式支持泛型 BasicMapper,无需为每个实体单独定义 Mapper 接口;一套 BasicMapper 即可驱动全部功能!
    2026 最好用的 ORM 框架:xbatis 1.9.7 正式发布,基于 mybatis 的 ORM 框架
  • 3:全面支持单 Mapper 架构,仅需定义一个 Mapper 接口即可完成所有数据操作

为何推荐 xbatis?:

xbatis 是一款兼具强大性与易用性的新一代 ORM 框架 1:原生支持多表 JOIN 查询(彻底告别单表限制) 2:同时支持代码级分页与 XML 级分页(无需依赖 PageHelper 等第三方插件) 3:卓越的可扩展性:融合 ORM + SQL 模板双模式(打破传统 ORM 固化瓶颈,扩展自由度极高) 4:深度数据库兼容能力:同一套代码可无缝切换多种数据库(连 Hibernate 都难以做到的跨库一致性) 6:API 设计极度精简,上手零门槛,开发者无需反复查阅文档
  1. 单表 + @Fetch 注解 + fetchFilter 方法

@Data
@ResultEntity(SysUser.class)
public class SysUserVo {
private Integer id;
private String userName;
private String password;
private Integer roleId;
private LocalDateTime create_time;
@Fetch(source = SysUser.class, property = "roleId", target = SysRole.class, targetProperty = "id")
private List sysRoles;
}
List list = QueryChain.of(sysUserMapper)
.from(SysUser.class)
.fetchFilter(SysUserVO::getRoles, where -> where.eq(SysRole::getStatus, 1))
.returnType(SysUserVO.class)
.list();

fetchFilter 是对 @Fetch 的增强补充,常规场景下可忽略使用

  1. 单表查询示例

SysUser sysUser = QueryChain.of(sysUserMapper)
.eq(SysUser::getId, 1)
.eq(SysUser::getUserName, "admin")
.get();
  1. VO 映射能力

@Data
@ResultEntity(SysUser.class)
public class SysUserVo {
private Integer id;
private String userName;
// 字段名不一致时通过注解映射
@ResultEntityField(property = "password")
private String pwd;
}
SysUserVO sysUserVO = QueryChain.of(sysUserMapper)
.eq(SysUser::getId, 1)
.eq(SysUser::getUserName, "admin")
.returnType(SysUserVO.class)
.get();
  1. JOIN 查询支持

@Data
@ResultEntity(SysUser.class)
public class SysUserVo {
private Integer id;
private String userName;
// 字段名不一致时映射
@ResultEntityField(property = "password")
private String pwd;

// 一对一嵌套映射  
@NestedResultEntity(target = SysRole.class)  
private SysRole sysRole;  

// 一对多嵌套映射  
@NestedResultEntity(target = SysRole.class)  
private List sysRoles;  

}

List list = QueryChain.of(sysUserMapper)
.from(SysUser.class)
.join(SysUser.class, SysRole.class)
.returnType(SysUserRoleVO.class)
.list();

更多高效、灵活、有趣的用法持续上线中,欢迎访问官网体验 ? https://www.php.cn/link/c0fd33132cf60f26b36f3e719c407beb

例如:

  1. 支持深层嵌套 JOIN:A → B → C 多层关联一键搞定
  1. 不依赖 JOIN:通过 @Fetch + fetchFilter 实现“A 查一次 + B 查一次”的优雅替代方案
  1. XML 分页自动化:添加 @Paging 注解,XML 中自动注入分页逻辑
  1. SQL 模板加持:让 ORM 更贴近业务,轻松应对复杂 SQL 场景,彻底摆脱框架束缚

源码地址:点击下载

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

841

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

742

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

737

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.7万人学习

C# 教程
C# 教程

共94课时 | 7.1万人学习

Java 教程
Java 教程

共578课时 | 48.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号