首页 > 数据库技术 > 详细

mybatis sql String>Double, 类型参数被强转为数值类型

时间:2015-09-13 02:12:08      阅读:904      评论:0      收藏:0      [点我收藏+]

?

最近项目中使用 mybatis 做为持久化层框架, 本来觉得还挺简单的, 这个框架的整体感觉是简单、直观明了,比较容易上手, 可是刚开始就遇到个棘手的问题,以为是配置哪里不对, 后来找了好久都没查出问题。 最后请教高手,帮忙解决了难题。

?

问题简要:

传入参数为String类型,xml配置文件也是VARCHAR类型,可以一旦传入字符类型的数据,就会抛出异常,?Error querying database.? Cause: java.lang.NumberFormatException: For input string: "XXX", 代码如下:

bubuko.com,布布扣
?经过高手多方查找, 解决方案如下:

bubuko.com,布布扣
?这样一来问题就解决了

?

?

参考资源 here

参考资源核心描述:

根据提示的信息,我们很容易知道是数据格式化的时候出了问题,不过为什么哪?我们定义的没有错呀!传递的也没有错呀!想不通,百度一下吧!下面是百度的一个结果,指明了引起错误原因的所在!是OGNL的语法问题,这里‘Y‘将被认为是char类型的数据,但是‘YY‘或者“Y”将被认为是String类型的数据,解决方案如下所示:

1:将代码改为test="param eq ‘Y‘.toString()"

2:将代码改为test="name == "Y""

3:将代码改为test=‘index == "Y"‘

当对象的映射文件及对应的属性如下编写时,<result column="IF_SHIELD" property="ifShield" jdbcType="VARCHAR" /> private?String?ifShield;

<if test="ifShield==1">是没问题的(并且数字是全部没问题的,无论是小数还是整数是正数还是负数),不过这样编写<result column="IF_SHIELD" property="ifShield" jdbcType="CHAR" /> private?String?ifShield;

<if test="ifShield==1">就是有问题的。

?参考如下:

http://www.cnblogs.com/tv151579/p/3297691.html

https://code.google.com/p/mybatis/issues/detail?id=262

mybatis sql String>Double, 类型参数被强转为数值类型

原文:http://davidhhs.iteye.com/blog/2242899

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!