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>
相关推荐
Boop_wu3 分钟前
Spring生态
java·后端·spring
jzheng86104 分钟前
Spring Boot(快速上手)
java·spring boot·后端
wgslucky4 分钟前
SpringBoot解决Request和Response的内容多次读取的问题
java·spring boot·多次读取request数据
Sylvia-girl21 分钟前
IO流~~
java·开发语言
冰暮流星33 分钟前
javascript之数组
java·前端·javascript
Re.不晚37 分钟前
JAVA进阶之路——无奖问答挑战3
java·开发语言
不倒翁玩偶1 小时前
IDEA导入新的SpringBoot项目没有启动按钮
java·spring boot·intellij-idea
小小小米粒1 小时前
Maven Tools
java
kali-Myon1 小时前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
我是咸鱼不闲呀1 小时前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划