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>
相关推荐
程序员侠客行21 分钟前
Tomcat 从陌生到熟悉
java·tomcat·web
wertyuytrewm23 分钟前
Java 异常|Java Exceptions
java·开发语言
ProgramHelpOa25 分钟前
Amazon SDE Intern OA 2026 最新复盘|70分钟两题 Medium-Hard
java·前端·javascript
雪碧聊技术32 分钟前
深入理解 Java GC:从“房间清洁工”到解决系统卡顿实战
java·开发语言
大鹏说大话38 分钟前
Java并发编程核心:线程安全、synchronized与volatile的深度剖析
java·开发语言
迷藏49440 分钟前
# 发散创新:低代码开发新范式——用可视化逻辑构建企业级业务系统 在当今快速迭代的软件工程实践
java·python·低代码
JAVA+C语言42 分钟前
Java IO 流
java·开发语言
山川行1 小时前
Python快速闯关8:内置函数
java·开发语言·前端·笔记·python·学习·visual studio
Java基基1 小时前
sdkman 一键切换 JDK 版本管理工具
java·开发语言·sdkman
美好的事情能不能发生在我身上1 小时前
Jmeter压测遇到的问题
java·分布式·jmeter