jOOQ代码生成器新增按生成模式过滤表功能详解
在数据库应用开发中,jOOQ作为一款优秀的ORM框架,其代码生成功能一直备受开发者青睐。最新版本中,jOOQ团队针对代码生成器做出了重要改进,新增了按不同生成模式(如Record、POJO、DAO)独立配置表过滤规则的功能,这将显著提升大型项目的编译效率。
功能背景
在之前的jOOQ版本中,开发者只能通过全局配置来决定是否为所有表生成各种对象类型(Record、POJO、DAO等)。但在实际项目中,我们往往只需要为少数关键表生成完整的对象类型,其余表可能仅需基础访问能力即可。特别是在多方言支持场景下,为每个测试表生成全套对象类型会导致编译时间急剧增加。
新增配置项
jOOQ 3.20.0版本引入了以下六个新的配置参数,使开发者能够精细控制不同生成模式下的表过滤规则:
<recordsIncludes/>- 指定需要生成Record类的表<recordsExcludes/>- 指定不生成Record类的表<pojosIncludes/>- 指定需要生成POJO类的表<pojosExcludes/>- 指定不生成POJO类的表<daosIncludes/>- 指定需要生成DAO类的表<daosExcludes/>- 指定不生成DAO类的表
技术实现原理
这些新配置项在代码生成阶段会被单独处理。jOOQ的代码生成器现在会为每种对象类型维护独立的过滤逻辑:
- 首先应用全局的
<includes/>和<excludes/>规则 - 然后针对特定对象类型应用对应的过滤规则
- 最终确定是否为当前表生成该类型的对象
这种分层过滤机制确保了配置的灵活性和向后兼容性。
典型应用场景
-
性能优化:在包含数百张表的项目中,只为业务核心的20张表生成POJO和DAO,其余表仅生成Record,可减少60%以上的生成代码量。
-
多方言测试:当为30种数据库方言生成测试代码时,只为测试专用的6张表生成完整对象类型,避免无谓的编译开销。
-
渐进式迁移:在传统项目向jOOQ迁移过程中,可以优先为改造中的模块生成完整对象类型。
配置示例
<generator>
<generate>
<!-- 全局配置 -->
<tables>true</tables>
<records>true</records>
<pojos>true</pojos>
<daos>true</daos>
</generate>
<!-- 按模式过滤 -->
<recordsIncludes>USER, ORDER, PRODUCT</recordsIncludes>
<pojosIncludes>USER, ORDER</pojosIncludes>
<daosIncludes>USER</daosIncludes>
</generator>
注意事项
- 这些配置项与现有
<includes/>和<excludes/>是叠加关系,而非替代关系 - 当同时配置includes和excludes时,excludes优先级更高
- 表名匹配规则与原有机制保持一致,支持通配符
- 对于复杂场景,仍可采用多代码生成配置的方式实现更精细控制
总结
这项改进使得jOOQ的代码生成策略更加灵活精细,特别有利于大型项目和多方言支持场景。通过减少不必要的代码生成,开发者可以获得更快的编译速度和更简洁的项目结构。随着jOOQ的持续演进,我们期待看到更多提升开发者体验的实用功能。
对于现有项目,建议评估各表对象的实际使用情况,逐步应用这些新的过滤规则来优化生成配置。在微服务架构中,甚至可以结合业务边界为不同服务配置不同的生成策略,实现架构层面的关注点分离。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0210
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0133
MinerUA high-quality tool for convert PDF to Markdown and JSON.一站式开源高质量数据提取工具,将PDF转换成Markdown和JSON格式。Python08
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
wgai开箱即用的JAVAAI在线训练识别平台&OCR平台AI合集包含旦不仅限于(车牌识别、安全帽识别、抽烟识别、常用类物识别等) 图片和视频识别,可自主训练任意场景融合了AI图像识别opencv、yolo、ocr、esayAI内核识别;AI智能客服、AI语言模型、 无任何第三方API接口可定制化自主离线化部署并自主化行业化使用避免占用内存、GPU消耗训练与识别分开使用;Java06
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03