mybatis映射时候的注意点

另外,请注意,结果映射中使用了column="sh.id",这意味着MyBatis会查找结果集中列名为sh.id的列。但是,在SQL中,我们使用sh.id作为列名,这会导致结果集中的列名也是sh.id(包括别名中的点)。

这可能会引起问题,因为点通常用于嵌套结果映射。实际上,在SQL中,使用sh.id作为列名,结果集中的列名会是sh.id(字符串),而不是id。这可能导致MyBatis无法正确映射。

1. 检查SQL别名和结果映射的对应关系

你的SQL是:

sql

复制代码
SELECT sh.id,sh.history_id,sh.announcement_id,u.id,u.avatar_url,u.nickname

但结果映射是:

xml

复制代码
<resultMap id="SeeHistoryWithUserVOResult" type="com.hgwy.notification.business.vo.SeeHistoryWithUserVO">
    <result property="id" column="sh.id"/>          <!-- SQL中是 sh.id -->
    <result property="userId" column="u.id"/>       <!-- SQL中是 u.id -->
    <result property="announcementId" column="sh.announcement_id"/>
    <result property="historyId" column="sh.history_id"/>
    <result property="avatarUrl" column="u.avatar_url"/>
    <result property="nickname" column="u.nickname"/>
</resultMap>

问题 :SQL中的列名是sh.id,但结果映射期望的列名是sh.id。实际上,SQL返回的列名中会包含.,这可能导致MyBatis无法正确映射。

2. 修改SQL使用别名(推荐)

将SQL修改为使用明确的无点号别名:

xml

复制代码
<select id="selectSeeHistoryUserList" parameterType="Long" resultMap="SeeHistoryWithUserVOResult">
    SELECT 
        sh.id as sh_id,
        sh.history_id as history_id,
        sh.announcement_id as announcement_id,
        u.id as user_id,
        u.avatar_url as avatar_url,
        u.nickname as nickname
    FROM see_history sh  
    LEFT JOIN `user` u ON sh.user_id = u.id 
    WHERE sh.announcement_id = #{announcementId}
</select>

相应地修改结果映射:

xml

复制代码
<resultMap id="SeeHistoryWithUserVOResult" type="com.hgwy.notification.business.vo.SeeHistoryWithUserVO">
    <result property="id" column="sh_id"/>
    <result property="userId" column="user_id"/>
    <result property="announcementId" column="announcement_id"/>
    <result property="historyId" column="history_id"/>
    <result property="avatarUrl" column="avatar_url"/>
    <result property="nickname" column="nickname"/>
</resultMap>
相关推荐
二哈赛车手8 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~9 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8299 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
未若君雅裁10 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记11 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI11 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
辰海Coding12 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
小小编程路12 小时前
C++ 多线程与并发
java·jvm·c++
AI视觉网奇12 小时前
linux 检索库 判断库是否支持
java·linux·服务器