Mybatis查詢方法如何實(shí)現(xiàn)沒有返回值
最近在項(xiàng)目開發(fā)中發(fā)現(xiàn)一件非常有意思的事情,一個(gè)Mapper.java文件中有一個(gè)查詢方法沒有返回值,這引起了我的好奇心,
沒有返回值查詢還有什么用呢?
仔細(xì)去看這個(gè)Mapper.java文件對應(yīng)的xml文件發(fā)現(xiàn),查詢正常,肯定是有返回值的。
可是為什么方法中卻沒有寫返回值呢?這就讓人感覺奇怪了。仔細(xì)查看方法,發(fā)現(xiàn)除了前面?zhèn)鬟f的兩個(gè)參數(shù)之外,最后還有一個(gè)參數(shù)KeyValueMapResultHandler,
那這個(gè)參數(shù)是用來做什么的呢?點(diǎn)進(jìn)去一看才知道它的用法。
它實(shí)現(xiàn)了一個(gè)接口ResultHandler<Map<String, Object>>,繼續(xù)看這個(gè)接口如下:
它是Mybatis提供的接口,里面只有一個(gè) 方法handleResult,直譯過來就是處理結(jié)果的意思。實(shí)際的用法是自定義處理Mybatis的查詢結(jié)果。
由實(shí)現(xiàn)類可知,傳入的泛型是一個(gè)Map集合Map<String, Object>,因此獲取的值也將是一個(gè)Map集合,如上圖中的這兩段代碼:
public class KeyValueMapResultHandler implements ResultHandler<Map<String, Object>>
Map<String, Object> map = resultContext.getResultObject();
簡單理解就是Mybatis提供了一個(gè)接口用來自定義處理查詢的結(jié)果,這個(gè)文件中是將查詢的結(jié)果轉(zhuǎn)換為key-value的形式,放在Map集合中方便取用。
如果是其他更加復(fù)雜的操作,也可以采取這種方式來進(jìn)行處理Mybatis查詢的結(jié)果集。
調(diào)用方式如下:
需要使用的時(shí)候,可以考慮采用這種處理方式。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Windows NT平臺下Oracle優(yōu)化策略簡介2. Oracle中利用ADO對象實(shí)現(xiàn)存取和訪問3. MySQL全文搜索之布爾搜索4. MySql中流程控制函數(shù)/統(tǒng)計(jì)函數(shù)/分組查詢用法解析5. sqlserver數(shù)據(jù)庫導(dǎo)入方法的詳細(xì)圖文教程6. Oracle的PDB數(shù)據(jù)庫創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問題及解決方法7. Oracle數(shù)據(jù)庫中SQL語句性能調(diào)整原則8. MySQL 的啟動選項(xiàng)和系統(tǒng)變量實(shí)例詳解9. SQL Server和Oracle并行處理方法對比10. navicat導(dǎo)入oracle導(dǎo)出的dmp文件
