MyBatis-Flex 代码生成器配置主键生成策略详解
在使用 MyBatis-Flex 的代码生成器时,正确配置主键生成策略是一个常见但容易被忽视的技术点。本文将深入解析如何通过 ColumnConfig 正确设置主键生成方式,避免配置不生效的问题。
问题背景
开发者在使用 MyBatis-Flex 代码生成器时,希望通过配置为实体类的主键字段添加特定的生成策略注解。例如,使用雪花算法(SnowFlake)作为ID生成器。初始配置如下:
ColumnConfig columnConfig = new ColumnConfig();
columnConfig.setKeyType(KeyType.Generator);
columnConfig.setKeyValue(KeyGenerators.snowFlakeId);
然而生成的实体类中,@Id 注解上并没有预期的生成策略配置:
@Id
private Long id;
问题原因分析
经过排查发现,问题出在 ColumnConfig 的配置方式上。关键点在于:
-
未指定目标列名:ColumnConfig 必须通过 setColumnName() 方法明确指定要配置的列名,否则配置无法关联到具体字段。
-
未将配置加入全局配置:创建好的 ColumnConfig 必须通过 globalConfig.setColumnConfig() 方法加入到全局配置中才会生效。
正确配置方式
正确的完整配置示例如下:
// 创建列配置
ColumnConfig columnConfig = new ColumnConfig();
// 指定要配置的列名
columnConfig.setColumnName("ID");
// 设置主键生成类型
columnConfig.setKeyType(KeyType.Generator);
// 设置具体的生成器
columnConfig.setKeyValue(KeyGenerators.snowFlakeId);
// 将列配置加入全局配置
globalConfig.setColumnConfig(columnConfig);
配置效果
应用上述正确配置后,生成的实体类将包含预期的主键生成策略注解:
@Id(keyType = KeyType.Generator, value = "snowFlakeId")
private Long id;
技术要点总结
-
明确目标列:必须通过 setColumnName() 指定要配置的具体列名,这是配置生效的前提。
-
配置完整性:除了设置 keyType 和 keyValue 外,必须将 ColumnConfig 实例加入到 GlobalConfig 中。
-
生成策略选择:MyBatis-Flex 提供了多种内置的 KeyGenerators,开发者可以根据需求选择:
- snowFlakeId:雪花算法ID
- uuid:UUID生成器
- 其他自定义生成器
-
全局配置管理:所有列级配置都需要通过 GlobalConfig 进行统一管理,这是 MyBatis-Flex 代码生成器的核心设计理念。
最佳实践建议
-
对于主键配置,建议在代码生成前仔细检查列名是否与数据库一致。
-
可以结合表名进行更精确的配置,避免不同表的同名列产生冲突。
-
对于复杂的项目,建议将配置代码模块化,提高可维护性。
-
生成后检查实体类是否符合预期,特别是注解部分。
通过正确理解和应用这些配置技巧,开发者可以充分利用 MyBatis-Flex 代码生成器的能力,高效生成符合项目需求的实体类代码。
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 StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112