Type handler was null on parameter mapping for property '__frch_id_0'

1.Type handler was null on parameter mapping for property ‘__frch_id_0’
2.Type handler was null on parameter mapping or property ‘__frch_item_0’
在SpringMVC+Mybaits项目中
出现了这样的错误很频繁,可以根据报错的信息锁定是在mapper中出了错。出错主要是在使用foreach语句的时候,两个foreach标签中间的参数写错了

例如:
我有一个model,还有一个list,通过ArrayList向mapper中传值

<select id="getMainInfo" parameterType="model" resultMap="java.util.List">
  select id, name from table 
where 
id in
  <foreach collection="list" item="param"  open="(" close=")" separator=",">  
        #{param.id}
//这里直接用#{id},就会报错
  </foreach>   
</select>

相关链接:

http://blog.csdn.net/rendeyishi/article/details/39479497

顺便介绍一下< foreach>标签的使用:
foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。foreach元素的属性主要有item,index,collection,open,separator,close。item表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔符,close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的,主要有一下3种情况:
1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .
2. 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array .
3. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.

—实际上JSP中的标签,用法与在mapper中使用的,也很类似

  • 18
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: “type handler was null on parameter mapping for property” 的意思是“参数映射中的属性类型处理程序为空”。这通常是因为在参数映射过程中,没有为属性指定类型处理程序,导致出现错误。要解决这个问题,需要检查参数映射配置,确保为每个属性指定了正确的类型处理程序。 ### 回答2: 在MyBatis中,通过mapper接口相关的方法进行操作数据库时,经常会遇到“type handler was null on parameter mapping for property”的错误提示。这个错误提示通常是由于参数映射失败导致的。 在MyBatis中,参数映射是将Java类型的参数映射到SQL参数的过程。在这个过程中,MyBatis会根据参数类型和配置的typeHandler来确定参数的数据类型,从而将参数正确地映射到SQL参数中。但是,当我们的参数类型和typeHandler没有正确配置时,就会出现“type handler was null on parameter mapping for property”这个错误。 要解决这个问题,我们需要确定哪个参数映射失败,并查看参数类型和typeHandler是否正确配置。可以通过在mapper方法上添加@Param注解,明确指定参数的名称,从而更容易确定哪个参数映射失败。 如果参数类型和typeHandler没有正确配置,需要在mapper.xml中将参数的类型和typeHandler正确配置。例如,在参数类型为Date时,可以指定typeHandler为org.apache.ibatis.type.LocalDateTimeTypeHandler,将参数正确转换为SQL参数。 除了参数类型和typeHandler的配置问题,还可能是mapper接口方法的定义问题导致的参数映射失败。在这种情况下,需要检查方法参数的名称和mapper.xml文件中参数的名称是否一致。 总之,在遇到“type handler was null on parameter mapping for property”这个错误时,我们应该先确定哪个参数映射失败,并查看参数类型和typeHandler是否正确配置。只有解决了参数映射失败的问题,才能正确地执行数据库操作。 ### 回答3: 在MyBatis框架中,有时会因为参数映射中的属性出现问题而出现“type handler was null on parameter mapping for property”的错误消息。这个错误通常表示参数映射中的属性没有找到相应的类型处理程序来处理它。 这个错误通常是因为在参数映射中使用了不支持或未注册的属性类型,或者因为找不到用于指定属性类型的自定义类型处理程序。 如果出现这种错误,可以采取以下步骤进行排查: 1. 检查参数映射中的属性是否正确:首先检查参数映射中的属性是否正确。确认属性名和类型是否与Java类中的定义一致。 2. 检查属性类型是否被支持:其次,检查属性类型是否被MyBatis框架所支持。MyBatis框架内置了众多的类型处理程序,这些类型处理程序可以帮助将数据从数据库中读取、写入,并将数据转换为Java对象的相应类型。如果属性类型不在这些类型处理程序的列表中,就需要手动注册自己的类型处理程序。 3. 注册自定义类型处理程序:如果属性类型不在MyBatis框架的类型处理程序列表中,那么需要自定义类型处理程序来支持该属性的类型转换。自定义类型处理程序的实现方式是实现TypeHandler接口,并重写该接口的方法。随后在mybatis-config.xml或Mapper XML文件中注册该类型处理程序。 总之,在解决“type handler was null on parameter mapping for property”错误时,需要检查参数映射中的属性是否正确,确认属性类型是否被支持或手动注册自定义类型处理程序。这样就能够有效地排除参数映射问题,使MyBatis框架能够正常地使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值