前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ibatis resultMap参数填充异常:java.sql.SQLException: Column 'XXX' not found.

ibatis resultMap参数填充异常:java.sql.SQLException: Column 'XXX' not found.

作者头像
执笔记忆的空白
发布2020-12-25 14:43:28
9840
发布2020-12-25 14:43:28
举报
文章被收录于专栏:Java日常

今天使用ibatis时,出现了一个让人开始很疑惑的异常,后面看官方文档才找到,是我用mybatis习惯了,所以对于ibatis的这种细节区分没太在意。问题是因为resultMap是一整个对象,而我的查询只查询了部分的字段值,在填充resultMap时,报了一个SQL异常,XXX字段没找到

Cause: java.sql.SQLException: Column 'XXXX' not found.

然后就顺带去分析mybatis和ibatis的区别:

1、在判断空值上面,iBatis是有标签的<isNotEmpty><isNotNull>等标签使用,MyBatis确是使用<if></if>来进行这些判断的

2、ibatis和Mybatis 对于 resultMap 填充值的区别:

iBatis中我们在查询多条数据的时候都会返回一个resultMap,那么我们查询的数据就和resultMap对应,那么有没有想过如果两边对不上会怎么样,特别是在resultMap公用的情况下,你在那边加会有什么影响等情况。 经过我的测试发现,如果查询的字段多了,resultMap对应的字段少了,不会报错,只是查询后后台取的的数据这个字段为NULL值 如果resultMap的字段多了,查询数据的时候没有查询出来这个数据,那么此时就会报错,比如说我查询的时候没有查询name这个字段,但是resultMap里面对应的有这个字段,就会报如下错误

Cause: java.sql.SQLException: Column 'name' not found.

而mybatis则不会报错,只是结果为空值而已

3、ibatis在动态传值时,只需要用#标记即可,而mybatis则需要使用el表达式一样#{}

先记到这,后续补充

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017/03/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档