项目背景
从数据库中查询相关的数据,类型为int。使用mybatis。
今天做项目遇到了一个问题,就是当使用mybatis时,映射参数到Map,我开始使用的是Map<String,Integer> getStateById(int id)
;来接受数据,但是后来却报错
报错:java.lang.Integer cannot be cast to java.lang.Long.
我并不知道原因,其实也就是类型转化错误,但是我在数据表中和后端中都没有设置Long类型呀,怎么会有数据转换问题?
解决方案
在然后在网上查阅资料,最终找到了一个解决方案:
将Map<String,Integer>
改为Map<String,Object> getStateById(int id)
;这样,无论mybatis映射的是什么数据类型,都将其先转化为Object,然后我们再在service
层中进行类型的转化,这样就可以在一定程度上避免类型转化问题。