游乐游手机版
首页/科技数码/文章详情

BeetlSQL 3.37发布 新增多对多自动关联查询

时间:2026-06-28 11:39
BeetlSQL3 37版本已经正式发布,新增全新的多对多自动Fetch功能,提供@FetchMany2Many注解及配套Action类,利用中间表来实现关联数据自动加载,能够极大简化复杂多表查询。同时修复了SQLServer表元数据读取异常,并升级底层模板引擎至3 20 1稳定版本。

BeetlSQL 自 2015 年起便投入研发,其核心模块及周边生态组件全部自主实现,未依赖任何第三方 ORM 内核。框架的设计目标极为明确:使开发者使用顺手、维护轻松、运行高效。简而言之,BeetlSQL 旨在提供一款学习成本极低、适用场景广泛且支持高度定制的数据库访问框架(Java ORM 框架)。

接下来,让我们一同了解本次版本更新带来的几项实用变化。

  • 修复了 SQL Server 在特定场景下无法正确读取表元数据的缺陷
  • Fetch 功能新增对多对多关系的自动加载支持
  • 底层模板引擎 Beetl 升级至最新的 3.20.1 版本

Fetch 方面新增了 @FetchMany2Many 注解,并配套提供 FetchMany2ManyAction 类(需结合 @Builder 使用)。通过中间表自动拉取多对多关联数据,现在变得非常自然流畅。以下为注解的定义:

@Retention(RetentionPolicy.RUNTIME)
@Target(value = {ElementType.METHOD, ElementType.FIELD})
@Builder(FetchMany2ManyAction.class)
public @interface FetchMany2Many {
    Class tableClass();       // 中间表对应的实体类
    String fromAttr();        // 当前实体在中间表中的外键字段名
    String toAttr();          // 关联实体在中间表中的外键字段名
    String enableOn() default ""; // 启用条件表达式(可选)
}

在实际使用中,代码显得格外简洁:

@Table(name="sys_user")
public class MyUser {
    @AutoID
    Integer id;
    String name;
    @FetchMany2Many(tableClass = UserRole.class, fromAttr = "userId", toAttr = "roleId")
    List roles;
}

BeetlSQL 核心模块说明

BeetlSQL 核心模块功能
sql-core基础核心模块,封装 JDBC 调用、SQL 文件管理、注解解析等核心能力
sql-fetch提供类似 Hibernate 的 `@Fetch`、`@FetchMany` 等懒加载/预加载注解支持
sql-mapperMapper 接口定义与扩展机制,支持用户自定义 Mapper 及其专属注解
sql-intergration集成主流框架(如 Spring、Solon、JFinal)的适配器与完整示例
sql-queryQuery 与 LambdaQuery 接口,支持通过 Java API 构建并执行 SQL
sql-mapping单表/多表与 POJO 的双向映射能力,支持 JSON、XML 或约定优先等多种配置方式
sql-template基于 Beetl 模板引擎实现 SQL 渲染,同时兼容其他模板语言扩展
sql-gen代码生成抽象层,内置默认实现,可一键生成 DAO、SQL 文件、接口文档等
sql-db-support覆盖 33+ 种数据库的兼容性测试与驱动验证
sql-samples涵盖上百个典型业务场景的实战案例
sql-test包含数百个高质量单元测试用例,保障稳定性与可靠性

BeetlSQL 官方扩展插件列表

BeetlSQL 扩展包功能
sql-xml仿 MyBatis XML 风格语法支持,适合习惯用 XML 编写 SQL 的开发者
sql-accelerator性能增强插件,通过反射优化、缓存策略等手段,使性能提升 50%–200%,逼近手写 JDBC 效率
sql-firewallSQL 防御模块,防止误操作导致的数据破坏或敏感信息泄露
sql-dynamic-table动态表访问支持,让程序像操作静态表一样处理运行时创建的表结构
sql-bean-encrypt字段级加解密支持,内置 `@MD5`、`@AES` 等常用加密注解
sql-rewriteSQL 重写引擎,支持单表多租户、逻辑删除、数据权限控制等功能
SAGA(实验性)基于 SAGA 模式的分布式事务实现,服务于微服务架构下的事务一致性需求

启用加速插件后的性能对比显示:最高可达到原生 JDBC 性能的一半左右。下表列出了各类常见操作的具体数据。

查询类型测试场景BeetlSQL (ops/ms)纯 JDBCMyBatisJPA
beetlsqlExecuteJdbc直接执行 JDBC 语句318678/64
beetlsqlExecuteTemplate执行 Beetl SQL 模板268/4466
beetlsqlFileSQL 统一存放于文件中管理266/41/
beetlsqlInsert单条记录插入1292484359
beetlsqlGetAll全量数据查询134045
beetlsqlLambdaQuery使用 LambdaQuery 构建并执行查询196/9/
beetlsqlPageQuery分页查询操作159/1759
beetlsqlSelectById根据主键查询单条记录2596704361

接下来,展示更全面的 JMH 基准测试结果(单位:ops/ms),涵盖多个主流 Java ORM 框架的对比:

Benchmark                                  Mode  Cnt     Score      Error   Units
Beetl.addEntity                           thrpt    5   133.190 ±   38.548  ops/ms
Beetl.complexMapping                      thrpt    5   236.289 ±  288.370  ops/ms
Beetl.executeJdbcSql                      thrpt    5   298.657 ±   80.480  ops/ms
Beetl.executeTemplateSql                  thrpt    5   251.418 ±   77.757  ops/ms
Beetl.getAll                              thrpt    5    14.531 ±    0.605  ops/ms
Beetl.getEntity                           thrpt    5   359.275 ±   85.099  ops/ms
Beetl.lambdaQuery                         thrpt    5   187.228 ±   59.697  ops/ms
Beetl.one2Many                            thrpt    5   178.041 ±  181.829  ops/ms
Beetl.pageQuery                           thrpt    5   148.982 ±   39.327  ops/ms
Beetl.sqlFile                             thrpt    5   249.206 ±  100.083  ops/ms
DBVisitor.addEntity                       thrpt    5    99.294 ±   33.564  ops/ms
DBVisitor.executeJdbcSql                  thrpt    5   185.177 ±   50.993  ops/ms
DBVisitor.executeTemplateSql              thrpt    5     3.189 ±    0.748  ops/ms
DBVisitor.getAll                          thrpt    5     3.163 ±    0.980  ops/ms
DBVisitor.getEntity                       thrpt    5   125.683 ±   44.190  ops/ms
DBVisitor.lambdaQuery                     thrpt    5    94.314 ±   38.499  ops/ms
DBVisitor.pageQuery                       thrpt    5    49.954 ±   18.254  ops/ms
EasyQuery.addEntity                       thrpt    5    98.904 ±   39.890  ops/ms
EasyQuery.complexMapping                  thrpt    5    67.397 ±   59.919  ops/ms
EasyQuery.executeJdbcSql                  thrpt    5   243.160 ±   48.080  ops/ms
EasyQuery.getAll                          thrpt    5    14.896 ±    2.219  ops/ms
EasyQuery.getEntity                       thrpt    5   134.370 ±   67.962  ops/ms
EasyQuery.lambdaQuery                     thrpt    5   137.292 ±   53.438  ops/ms
EasyQuery.one2Many                        thrpt    5    75.083 ±   53.738  ops/ms
EasyQuery.pageQuery                       thrpt    5    84.596 ±   46.942  ops/ms
Flex.addEntity                            thrpt    5    86.484 ±   40.022  ops/ms
Flex.getAll                               thrpt    5     2.926 ±    0.993  ops/ms
Flex.getEntity                            thrpt    5    73.445 ±   39.437  ops/ms
Flex.pageQuery                            thrpt    5    33.999 ±   26.776  ops/ms
Jdbc.addEntity                            thrpt    5   225.223 ±  304.585  ops/ms
Jdbc.executeJdbcSql                       thrpt    5   691.616 ±  145.280  ops/ms
Jdbc.getAll                               thrpt    5    35.827 ±    7.295  ops/ms
Jdbc.getEntity                            thrpt    5   678.791 ±  165.527  ops/ms
Jpa.addEntity                             thrpt    5    53.219 ±   78.543  ops/ms
Jpa.executeJdbcSql                        thrpt    5    60.734 ±   61.299  ops/ms
Jpa.executeTemplateSql                    thrpt    5    64.478 ±   48.688  ops/ms
Jpa.getAll                                thrpt    5     4.710 ±    2.062  ops/ms
Jpa.getEntity                             thrpt    5    56.325 ±   53.744  ops/ms
Jpa.one2Many                              thrpt    5    92.168 ±  111.591  ops/ms
Jpa.pageQuery                             thrpt    5    58.756 ±   48.056  ops/ms
MyBatis.addEntity                         thrpt    5    40.533 ±   12.461  ops/ms
MyBatis.complexMapping                    thrpt    5   106.348 ±   57.688  ops/ms
MyBatis.executeTemplateSql                thrpt    5    46.953 ±   13.541  ops/ms
MyBatis.getAll                            thrpt    5     5.394 ±    0.502  ops/ms
MyBatis.getEntity                         thrpt    5    45.303 ±   11.928  ops/ms
MyBatis.lambdaQuery                       thrpt    5    23.756 ±   13.613  ops/ms
MyBatis.pageQuery                         thrpt    5    16.190 ±    5.682  ops/ms
MyBatis.sqlFile                           thrpt    5    42.558 ±   18.025  ops/ms
SqlUtils.addEntity                        thrpt    5   232.501 ±  332.656  ops/ms
SqlUtils.executeJdbcSql                   thrpt    5   682.610 ±  171.506  ops/ms
SqlUtils.getAll                           thrpt    5    44.353 ±    4.346  ops/ms
SqlUtils.getEntity                        thrpt    5   643.873 ±  131.587  ops/ms
Wood.addEntity                            thrpt    5   105.097 ±   79.961  ops/ms
Wood.executeJdbcSql                       thrpt    5   127.020 ±   48.142  ops/ms
Wood.executeTemplateSql                   thrpt    5   129.193 ±   44.455  ops/ms
Wood.getAll                               thrpt    5     2.051 ±    0.524  ops/ms
Wood.getEntity                            thrpt    5   126.104 ±   41.976  ops/ms
Wood.lambdaQuery                          thrpt    5   125.013 ±   43.991  ops/ms
Wood.pageQuery                            thrpt    5   220.101 ±   90.028  ops/ms
Wood.sqlFile                              thrpt    5   132.431 ±   50.141  ops/ms
来源:https://www.php.cn/faq/2008655.html?uid=1246273
上一篇守艺传承·焕新非遗 射阳县2026年文化和自然遗产日系列活动圆满落幕 下一篇暑期旅游市场持续升温 一个隐忧不得不防
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
年国家能源局充换电服务业用电量增速48.8%
科技数码 · 2026-06-29

年国家能源局充换电服务业用电量增速48.8%

2025年全社会用电量达103682亿千瓦时,同比增长5 0%。充换电服务业用电增速高达48 8%,信息传输与软件服务业增速17 0%。第三产业和居民用电对增长贡献率合计占一半。中国成为全球首个年度用电量超10 4万亿千瓦时的国家。

追风者 GLACIER ONE 360 S25 液冷散热器新品上市 联体风扇售价429元
科技数码 · 2026-06-29

追风者 GLACIER ONE 360 S25 液冷散热器新品上市 联体风扇售价429元

追风者冰川360S25液冷散热器售价429元,三联一体风扇便捷安装,冷头小体积纯铜底座噪音18dB,风扇转速300-2000RPM、风量75CFM、静压2 96mmAq,五年质保漏液包赔。

三星Galaxy Watch8用户反馈谷歌后台组件异常
科技数码 · 2026-06-29

三星Galaxy Watch8用户反馈谷歌后台组件异常

三星GalaxyWatch8、Watch5Pro、Watch6及Watch7用户反映,GooglePlayServices后台耗电异常,电量占比最高达99 97%,远超正常水平,严重影响续航。目前故障原因不明,谷歌尚未发布官方声明。

罗永浩批苹果iOS 27创新不足 盼新CEO改进
科技数码 · 2026-06-29

罗永浩批苹果iOS 27创新不足 盼新CEO改进

罗永浩批评苹果iOS27创新不足,称仅有双iPhone同号、音量分离等数十项细节改进,认为库克时代缺乏突破性创新,股市虽好但消费者只能被迫接受挤牙膏式升级。

年国产车出口710万辆,两家车企销量破百万
科技数码 · 2026-06-29

年国产车出口710万辆,两家车企销量破百万

2025年国产汽车出口总量达710万辆,同比增长21%。奇瑞以134万辆居首,比亚迪105万辆次之,上汽乘用车出口占比60%最高,长城出口51万辆。吉利、长安等主流品牌同步增长,小鹏、零跑等新兴品牌海外拓展加速。