myBatis插入操作获取不到返回的自增id问题
myBatis插入操作后想返回自增 id 有多种方式
其中一种使用率较高的就是:
在<insert></insert> 标签中添加 useGeneratedKeys 和 keyProperty 属性
具体操作可以看我另一篇博客
但是就是没有返回出来,结果是因为 我在 mapper 接口中入参时使用了 @Param 注解
当使用了 @Param 注解后,想把 insert 插入操作成功后的自增 id 返回出来,需要在
keyProperty 设置值时,添加 @Param("xxx") 括号中定义的别名
例:
Mapper 接口:
Long insertStudent(@Param("data")Student student);
Mapper xml:
<insert id="insertStudent" parameterType="com.test.Student" useGeneratedKeys="true" keyProperty="data.id"> </insert>
这样在业务逻辑层调用 mapper 接口后,在入参的对象中就可以 get 到对应的自增 id 了!
希望能够帮助到你
over
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异