解決MyBatis @param注解參數(shù)類型錯誤異常的問題
今天使用mybatis遇到個很奇怪的問題,我使用一個參數(shù)@param('threshold'),類型是java的double,但是很奇怪,一直告訴我參數(shù)轉(zhuǎn)換錯誤,int不能轉(zhuǎn)double,我就奇怪了,哪里來的int。
解決辦法我感覺可能使用用到了mybatis的關(guān)鍵字,所以就把threshold換了個名字,果然好了。
問題原因某些關(guān)鍵詞,mybatis會認為是某種類型,下面列出來一些,后面發(fā)現(xiàn)再補充。
size, threshold, modCount是int類型
loadFactor是float類型
補充:mybatis使用@Param的坑
在mybatis中@Param注解的作用是為參數(shù)指定一個名稱,在mapper文件中使用,而不是使用mybatis的arguments[0,1…]代替。但是在非動態(tài)的mapper——mybatis根據(jù)mapper接口創(chuàng)建實現(xiàn)類,@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)部類 MethodSignature 中。
根據(jù)源碼一步一步的遞歸:MethodSignature的構(gòu)造方法——>MapperMethod的構(gòu)造方法——>MapperProxy的cachedMapperMethod 和invoke方法 ——> MapperProxyFactory中的 newInstance 方法。
@SuppressWarnings('unchecked') protected T newInstance(MapperProxy<T> mapperProxy) {//jdk的動態(tài)代理生成mapper對象 return (T) Proxy.newProxyInstance(mapperInterface.getClassLoader(), new Class[] { mapperInterface }, mapperProxy); } public T newInstance(SqlSession sqlSession) {//MapperProxy實現(xiàn)了Invocation接口 final MapperProxy<T> mapperProxy = new MapperProxy<T>(sqlSession, mapperInterface, methodCache); return newInstance(mapperProxy); }
在整合spring與mybatis,使用spring提供的sqlSessionTemplate進行查詢時,沒有從MapperRegistry的mapper緩存集合中取mapper,而是直接使用配置的sqlSessionTemplate。
所以這種清況下,@param注解是無效的。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. CentOS6.7系統(tǒng)中編譯安裝MariaDB數(shù)據(jù)庫2. 一次SQL查詢優(yōu)化原理分析(900W+數(shù)據(jù)從17s到300ms)3. 詳解MySQL的Seconds_Behind_Master4. Microsoft Office Access調(diào)整控件大小的方法5. MySQL MyISAM 與InnoDB 的區(qū)別6. SQLite 實現(xiàn)if not exist 類似功能的操作7. Mysql入門系列:MYSQL表達式求值和MYSQL類型轉(zhuǎn)換8. MySql遠程連接的實現(xiàn)方法9. MySQL插入數(shù)據(jù)時,如果記錄不存在則insert,如果存在則update10. Mysql入門系列:建立MYSQL客戶機程序的一般過程
