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

 

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

 

问题简要:

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


 经过高手多方查找, 解决方案如下:


 这样一来问题就解决了

 

 

参考资源 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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MyBatis是一种使用XML或注解与数据库进行交互的Java持久层框架。在MyBatis中,各种SQL指令和参数都需要绑定到Java对象上,使用不同的参数类型可以使我们更轻松地操作数据库。 在MyBatis中,参数类型包括基本数据类型、包装类、Java Bean、Map和注解@Param等几种。 1. 基本数据类型和包装类:例如int、double、float等基本类型以及它们对应的包装类型Integer、Double、Float等都可以作为参数类型。在SQL语句中,我们使用#{}或${}占位符来代替这些参数。 2. Java Bean:我们也可以将自己封装的Java类作为参数传递给MyBatisSQL语句。在这种情况下,可以使用“.”符号将属性名连接在一起进行映射。例如: ```java public class User { private int id; private String name; private int age; //getter和setter } <select id="getUserById" resultType="com.example.User"> select * from user where user_id = #{id} </select> ``` 3. Map类型MyBatis中也可以使用Map类型来传递参数。使用Map类型的好处是我们可以灵活地在程序中添加或删除参数。例如: ```java <select id="getUserById" resultType="com.example.User"> select * from user where user_id = #{map.userId} </select> ``` 4. 注解@Param:使用@Param注解可以给SQL语句中的参数指定一个名称,使我们更加方便地调用。例如: ```java @Select("select * from user where user_name = #{name}") User getUserByName(@Param("name") String name); ``` 总之,在使用MyBatis框架的时候,我们要根据实际情况选择不同的参数类型,在这些参数类型中进行转化操作,方便我们与数据库进行交互。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值