0

0

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

心靈之曲

心靈之曲

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

|

1152人浏览过

|

来源于php中文网

原创

1.9.7 版本更新日志

  • 1:VO 字段注解现支持通过 set 方法上的注解覆盖默认行为
  • 2:数据库类型适配能力增强,新增对自定义 DbType 的全面支持
  • 3:getById 方法扩展,新增 getOptionalById 方法,返回 Optional<t></t> 类型结果
  • 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 场景写法,提供更直观的链式调用支持

MeloCool
MeloCool

AI歌曲生成器 - 歌词转歌曲AI音乐制作器在线工具

下载

通用 SQL 扩展能力:

// 支持任意类型:实体类、VO 或普通 POJO  
SysUser user = sysUserMapper.select(SysUser.class, "select * from t_sys_user where id =?", 1);  
<p>// 支持增删改操作,并可返回指定字段值(如更新后的新用户名)<br>
String user_name = sysUserMapper.executeAndReturning(String.class, "update t_sys_user set user_name=? where id=1 RETURNING user_name", "xxx");  </p><p>// ORM 风格:删除并返回被删记录(基于数据库原生 RETURNING)<br>
List<SysUser> list = DeleteChain.of(sysUserMapper)<br>
.in(SysUser::getId, 1, 2)<br>
.returning(SysUser.class)<br>
.returnType(SysUser.class)<br>
.executeAndReturningList();  </p><p>// ORM 风格:更新并返回更新后的完整对象(适用于金额加减等需确认结果场景)<br>
SysUser sysUser = UpdateChain.of(sysUserMapper)<br>
.eq(SysUser::getId, 1)<br>
.set(SysUser::getUserName, "abc2")<br>
.returning(SysUser.class)<br>
.returnType(SysUser.class)<br>
.executeAndReturning();</p>

分表配置示例:

@Data<br>
@SplitTable(SysUserSplitter.class)<br>
public class SysUser {<br>
@TableId<br>
private Integer id;<br>
@SplitTableKey<br>
private Integer groupId;<br>
private String nickname;<br>
private String username;<br>
}
public class SysUserSplitter implements TableSplitter {<br>
@Override<br>
public boolean support(Class<?> type) {<br>
return type == Integer.class || type == int.class;<br>
}  <pre class="brush:php;toolbar:false;">@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<br>
@ResultEntity(SysUser.class)<br>
public class SysUserVo {<br>
private Integer id;<br>
private String userName;<br>
private String password;<br>
private Integer roleId;<br>
private LocalDateTime create_time;<br>
@Fetch(source = SysUser.class, property = "roleId", target = SysRole.class, targetProperty = "id")<br>
private List<SysRoleVo> sysRoles;<br>
}
List<SysUserVo> list = QueryChain.of(sysUserMapper)<br>
.from(SysUser.class)<br>
.fetchFilter(SysUserVO::getRoles, where -> where.eq(SysRole::getStatus, 1))<br>
.returnType(SysUserVO.class)<br>
.list();

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

  1. 单表查询示例

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

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

@Data<br>
@ResultEntity(SysUser.class)<br>
public class SysUserVo {<br>
private Integer id;<br>
private String userName;<br>
// 字段名不一致时映射<br>
@ResultEntityField(property = "password")<br>
private String pwd;  <pre class="brush:php;toolbar:false;">// 一对一嵌套映射  
@NestedResultEntity(target = SysRole.class)  
private SysRole sysRole;  

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

}

List<SysUserRoleVO> list = QueryChain.of(sysUserMapper)<br>
.from(SysUser.class)<br>
.join(SysUser.class, SysRole.class)<br>
.returnType(SysUserRoleVO.class)<br>
.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 场景,彻底摆脱框架束缚

源码地址:点击下载

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1110

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2068

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1602

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

439

2024.04.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

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

精品课程

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

共23课时 | 4.2万人学习

C# 教程
C# 教程

共94课时 | 10.8万人学习

Java 教程
Java 教程

共578课时 | 78.3万人学习

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

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