Mybatis查詢方法如何實現(xiàn)沒有返回值
最近在項目開發(fā)中發(fā)現(xiàn)一件非常有意思的事情,一個Mapper.java文件中有一個查詢方法沒有返回值,這引起了我的好奇心,
沒有返回值查詢還有什么用呢?
仔細去看這個Mapper.java文件對應的xml文件發(fā)現(xiàn),查詢正常,肯定是有返回值的。
可是為什么方法中卻沒有寫返回值呢?這就讓人感覺奇怪了。仔細查看方法,發(fā)現(xiàn)除了前面?zhèn)鬟f的兩個參數(shù)之外,最后還有一個參數(shù)KeyValueMapResultHandler,
那這個參數(shù)是用來做什么的呢?點進去一看才知道它的用法。
它實現(xiàn)了一個接口ResultHandler<Map<String, Object>>,繼續(xù)看這個接口如下:
它是Mybatis提供的接口,里面只有一個 方法handleResult,直譯過來就是處理結(jié)果的意思。實際的用法是自定義處理Mybatis的查詢結(jié)果。
由實現(xiàn)類可知,傳入的泛型是一個Map集合Map<String, Object>,因此獲取的值也將是一個Map集合,如上圖中的這兩段代碼:
public class KeyValueMapResultHandler implements ResultHandler<Map<String, Object>>
Map<String, Object> map = resultContext.getResultObject();
簡單理解就是Mybatis提供了一個接口用來自定義處理查詢的結(jié)果,這個文件中是將查詢的結(jié)果轉(zhuǎn)換為key-value的形式,放在Map集合中方便取用。
如果是其他更加復雜的操作,也可以采取這種方式來進行處理Mybatis查詢的結(jié)果集。
調(diào)用方式如下:
需要使用的時候,可以考慮采用這種處理方式。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 用SQL語句查找Access中某表是否存在的小技巧2. SQL SERVER2000中訂閱與發(fā)布的具體操作3. Mariadb數(shù)據(jù)庫主從復制同步配置過程實例4. 如何:創(chuàng)建和運行 CLR SQL Server 用戶定義的函數(shù)5. MySQL中 and or 查詢的優(yōu)先級分析6. Microsoft Office Access添加外鍵的方法7. 解決Oracle模擬事務提交、表鎖,處理表鎖問題8. MySQL中查詢json格式的字段實例詳解9. 教你如何通過PL/SQL創(chuàng)建序列和觸發(fā)器實現(xiàn)表自增字段10. 高并發(fā)狀態(tài)下Replace Into造成的死鎖問題解決
