解決MyBatis @param注解參數(shù)類(lèi)型錯(cuò)誤異常的問(wèn)題
今天使用mybatis遇到個(gè)很奇怪的問(wèn)題,我使用一個(gè)參數(shù)@param('threshold'),類(lèi)型是java的double,但是很奇怪,一直告訴我參數(shù)轉(zhuǎn)換錯(cuò)誤,int不能轉(zhuǎn)double,我就奇怪了,哪里來(lái)的int。
解決辦法我感覺(jué)可能使用用到了mybatis的關(guān)鍵字,所以就把threshold換了個(gè)名字,果然好了。
問(wèn)題原因某些關(guān)鍵詞,mybatis會(huì)認(rèn)為是某種類(lèi)型,下面列出來(lái)一些,后面發(fā)現(xiàn)再補(bǔ)充。
size, threshold, modCount是int類(lèi)型
loadFactor是float類(lèi)型
補(bǔ)充:mybatis使用@Param的坑
在mybatis中@Param注解的作用是為參數(shù)指定一個(gè)名稱(chēng),在mapper文件中使用,而不是使用mybatis的arguments[0,1…]代替。但是在非動(dòng)態(tài)的mapper——mybatis根據(jù)mapper接口創(chuàng)建實(shí)現(xiàn)類(lèi),@param注解是不起作用的。
閱讀mybatis的源碼得知,檢查@param注解的方法:private boolean hasNamedParams(Method method) { boolean hasNamedParams = false; final Object[][] paramAnnos = method.getParameterAnnotations(); for (Object[] paramAnno : paramAnnos) { for (Object aParamAnno : paramAnno) { if (aParamAnno instanceof Param) { hasNamedParams = true; break; } } } return hasNamedParams; }
此方法位于 org.apache.ibatis.binding.MapperMethod 的內(nèi)部類(lèi) MethodSignature 中。
根據(jù)源碼一步一步的遞歸:MethodSignature的構(gòu)造方法——>MapperMethod的構(gòu)造方法——>MapperProxy的cachedMapperMethod 和invoke方法 ——> MapperProxyFactory中的 newInstance 方法。
@SuppressWarnings('unchecked') protected T newInstance(MapperProxy<T> mapperProxy) {//jdk的動(dòng)態(tài)代理生成mapper對(duì)象 return (T) Proxy.newProxyInstance(mapperInterface.getClassLoader(), new Class[] { mapperInterface }, mapperProxy); } public T newInstance(SqlSession sqlSession) {//MapperProxy實(shí)現(xiàn)了Invocation接口 final MapperProxy<T> mapperProxy = new MapperProxy<T>(sqlSession, mapperInterface, methodCache); return newInstance(mapperProxy); }
在整合spring與mybatis,使用spring提供的sqlSessionTemplate進(jìn)行查詢時(shí),沒(méi)有從MapperRegistry的mapper緩存集合中取mapper,而是直接使用配置的sqlSessionTemplate。
所以這種清況下,@param注解是無(wú)效的。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. 使用SQL語(yǔ)句快速獲取SQL Server數(shù)據(jù)字典3. 超大型Oracle數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的設(shè)計(jì)方法4. MySQL性能突然下降的原因5. Windows下在DOS用mysql命令行導(dǎo)入.sql文件6. oracle觸發(fā)器介紹7. MySQL創(chuàng)始人發(fā)郵件尋求中國(guó)幫助8. 50種方法巧妙優(yōu)化SQL Server數(shù)據(jù)庫(kù)9. Oracle災(zāi)難防護(hù)的關(guān)鍵技術(shù)10. 數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL
