resultMap 和 resultType 的字段映射覆盖问题
1.resultMap 和 resultType 的字段映射覆盖问题
2.GeometryCollection 的类型映射器(TypeHandler)3.自定义typeHandler将包含经纬度对象插入到mysql的point类型的字段中在MyBatis中,如果你使用resultType而不是resultMap,并且结果集中有同名字段,则默认情况下后出现的字段值会覆盖前面的字段值。这是因为MyBatis在将结果集映射到Java对象时,是按照字段名称一一对应进行赋值的。
但若你希望更精确地控制映射关系,并且避免自动覆盖行为,则可以用resultMap来显式指定每个字段应该映射到哪个属性上,它在遇到同名字段时不会进行覆盖,尤其是当涉及到多表查询时。
例如,如果有两个表中的字段名相同,你可以分别为它们起不同的别名:
<select id="selectExample" resultMap="combinedResult">
SELECT
t1.id as t1_id,
t2.id as t2_id,
...
FROM table1 t1
LEFT JOIN table2 t2 ON t1.id = t2.t1_id
</select>
<resultMap id="combinedResult" type="YourJavaType">
<id property="idFromTable1" column="t1_id"/>
<!-- 其他来自table1的字段 -->
<id property="idFromTable2" column="t2_id"/>
<!-- 其他来自table2的字段 -->
</resultMap>
这样通过column属性指定了数据库中的字段别名与Java实体类中属性的对应关系,即使字段名相同,也能确保正确映射到不同属性上而不会被覆盖。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· 10亿数据,如何做迁移?
· 推荐几款开源且免费的 .NET MAUI 组件库
· c# 半导体/led行业 晶圆片WaferMap实现 map图实现入门篇