Mybatis查詢(xún)方法如何實(shí)現(xiàn)沒(méi)有返回值
最近在項(xiàng)目開(kāi)發(fā)中發(fā)現(xiàn)一件非常有意思的事情,一個(gè)Mapper.java文件中有一個(gè)查詢(xún)方法沒(méi)有返回值,這引起了我的好奇心,
沒(méi)有返回值查詢(xún)還有什么用呢?
仔細(xì)去看這個(gè)Mapper.java文件對(duì)應(yīng)的xml文件發(fā)現(xiàn),查詢(xún)正常,肯定是有返回值的。
可是為什么方法中卻沒(méi)有寫(xiě)返回值呢?這就讓人感覺(jué)奇怪了。仔細(xì)查看方法,發(fā)現(xiàn)除了前面?zhèn)鬟f的兩個(gè)參數(shù)之外,最后還有一個(gè)參數(shù)KeyValueMapResultHandler,
那這個(gè)參數(shù)是用來(lái)做什么的呢?點(diǎn)進(jìn)去一看才知道它的用法。
它實(shí)現(xiàn)了一個(gè)接口ResultHandler<Map<String, Object>>,繼續(xù)看這個(gè)接口如下:
它是Mybatis提供的接口,里面只有一個(gè) 方法handleResult,直譯過(guò)來(lái)就是處理結(jié)果的意思。實(shí)際的用法是自定義處理Mybatis的查詢(xún)結(jié)果。
由實(shí)現(xiàn)類(lèi)可知,傳入的泛型是一個(gè)Map集合Map<String, Object>,因此獲取的值也將是一個(gè)Map集合,如上圖中的這兩段代碼:
public class KeyValueMapResultHandler implements ResultHandler<Map<String, Object>>
Map<String, Object> map = resultContext.getResultObject();
簡(jiǎn)單理解就是Mybatis提供了一個(gè)接口用來(lái)自定義處理查詢(xún)的結(jié)果,這個(gè)文件中是將查詢(xún)的結(jié)果轉(zhuǎn)換為key-value的形式,放在Map集合中方便取用。
如果是其他更加復(fù)雜的操作,也可以采取這種方式來(lái)進(jìn)行處理Mybatis查詢(xún)的結(jié)果集。
調(diào)用方式如下:
需要使用的時(shí)候,可以考慮采用這種處理方式。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 掌握SQL Server實(shí)戰(zhàn)教程之SQL Server的安裝指南2. Mybatis常見(jiàn)注解有哪些(總結(jié))3. SQL Server 2000數(shù)據(jù)庫(kù)崩潰后的補(bǔ)救措施4. ORACLE中常用的幾種正則表達(dá)式小結(jié)5. MySQL中 concat函數(shù)的使用6. 詳解MySQL中事務(wù)的持久性實(shí)現(xiàn)原理7. MySQL 語(yǔ)句大全:創(chuàng)建、授權(quán)、查詢(xún)、修改8. mysql利用mysqlbinlog命令恢復(fù)誤刪除數(shù)據(jù)的實(shí)現(xiàn)9. PyCharm MySQL可視化Database配置過(guò)程圖解10. 詳解MySQL批量入庫(kù)的幾種方式
