Mybatis使用MySQL模糊查詢時(shí)輸入中文檢索不到結(jié)果怎么辦
項(xiàng)目開(kāi)發(fā)中,在做Mybatis動(dòng)態(tài)查詢時(shí),遇到了一個(gè)問(wèn)題:MySQL在進(jìn)行LIKE模糊查詢時(shí),輸入英文可以正常檢索出結(jié)果,但是輸入中文后檢索得到的結(jié)果為空。
由于是使用GET方式請(qǐng)求,所以為了確保中文不亂碼,在控制臺(tái)接收到請(qǐng)求參數(shù)后,對(duì)中文進(jìn)行了一次編碼。
try {
realName = new String(realName.getBytes("GBK"), "UTF-8");
} catch (UnsupportedEncodingException exception) {
logger.error("realName在進(jìn)行UTF-8編碼時(shí)出錯(cuò)," + exception.toString());
}
Mybatis動(dòng)態(tài)SQL映射,具體的SQL如下:

首先使用模糊查詢檢索英文。啟動(dòng)項(xiàng)目,輸入英文“test”,按照英文內(nèi)容檢索得到的結(jié)果如下圖:

我們可以看到SQL正常執(zhí)行,使用“test”總共檢索出2條結(jié)果,數(shù)據(jù)庫(kù)中對(duì)應(yīng)字段的內(nèi)容分別是張三test02和張三test,正常來(lái)說(shuō),如果我們輸入中文“張”也可以查詢到這兩條數(shù)據(jù),下面試試使用模糊查詢檢索中文。啟動(dòng)項(xiàng)目,輸入中文“張”,檢索得到結(jié)果如下圖:

我們可以看到這里檢索出的結(jié)果是0條記錄,并且條件的中文內(nèi)容沒(méi)有亂碼,和預(yù)想中的并不一樣。復(fù)制同樣的SQL語(yǔ)句到SQLyog中執(zhí)行是可以正常檢索出結(jié)果的。
在使用SQLServer時(shí)并沒(méi)有出現(xiàn)過(guò)這樣的問(wèn)題,這次使用MySQL才出現(xiàn)這種情況,懷疑是在Mybatis配置數(shù)據(jù)源environment時(shí)SQLServer和MySQL配置的內(nèi)容有差異,仔細(xì)對(duì)比并上網(wǎng)查閱相關(guān)內(nèi)容后發(fā)現(xiàn),MySQL在進(jìn)行中文檢索時(shí),需要在jdbcURL后增加參數(shù)useUnicode=true&characterEncoding=UTF-8來(lái)指定編碼格式。

完整的URL:
jdbc:mysql://127.0.0.1:3306/fanyl_web?useUnicode=true&characterEncoding=UTF-8
在修改了MySQL的jdbcURL后,啟動(dòng)項(xiàng)目,繼續(xù)輸入中文“張”,檢索得到結(jié)果如下:

總共檢索出3條結(jié)果,至此Mybatis使用MySQL進(jìn)行模糊查詢時(shí)輸入中文檢索不到結(jié)果的問(wèn)題就解決了。
另外再附上MySQL的jdbcURL中常見(jiàn)的幾個(gè)參數(shù)說(shuō)明:

以上所述是小編給大家介紹的Mybatis使用MySQL模糊查詢時(shí)輸入中文檢索不到結(jié)果怎么辦,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
SpringBoot+MySQL實(shí)現(xiàn)讀寫(xiě)分離的多種具體方案
在高并發(fā)和大數(shù)據(jù)量的場(chǎng)景下,數(shù)據(jù)庫(kù)成為了系統(tǒng)的瓶頸。為了提高數(shù)據(jù)庫(kù)的處理能力和性能,讀寫(xiě)分離成為了一種常用的解決方案,本文將介紹在Spring?Boot項(xiàng)目中實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)讀寫(xiě)分離的多種具體方案,需要的朋友可以參考下2023-06-06
mybatis中實(shí)現(xiàn)枚舉自動(dòng)轉(zhuǎn)換方法詳解
在使用mybatis的時(shí)候經(jīng)常會(huì)遇到枚舉類型的轉(zhuǎn)換,下面這篇文章主要給大家介紹了關(guān)于mybatis中實(shí)現(xiàn)枚舉自動(dòng)轉(zhuǎn)換的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-08-08
SpringCloud微服務(wù)架構(gòu)升級(jí)匯總
這篇文章主要介紹了SpringCloud微服務(wù)架構(gòu)升級(jí)匯總,它提倡將單一應(yīng)用程序劃分成一組小的服務(wù),服務(wù)之間互相協(xié)調(diào)、互相配合,為用戶提供最終價(jià)值,需要的朋友可以參考下2019-06-06
Eclipse maven項(xiàng)目lombok安裝配置圖解
這篇文章主要介紹了Eclipse maven項(xiàng)目lombok安裝配置圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
SpringCloud微服務(wù)網(wǎng)關(guān)限流方式
這篇文章主要介紹了SpringCloud微服務(wù)網(wǎng)關(guān)限流方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
連續(xù)調(diào)用多個(gè)外部系統(tǒng)寫(xiě)接口保證數(shù)據(jù)一致性的思路
今天小編就為大家分享一篇關(guān)于連續(xù)調(diào)用多個(gè)外部系統(tǒng)寫(xiě)接口保證數(shù)據(jù)一致性的思路,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12
java Spring MVC4環(huán)境搭建實(shí)例詳解(步驟)
spring WEB MVC框架提供了一個(gè)MVC(model-view-controller)模型-視圖-控制器的結(jié)構(gòu)和組件,利用它可以開(kāi)發(fā)更靈活、松耦合的web應(yīng)用。MVC模式使得整個(gè)服務(wù)應(yīng)用的各部分(控制邏輯、業(yè)務(wù)邏輯、UI界面展示)分離開(kāi)來(lái),使它們之間的耦合性更低2017-08-08
SpringMVC中事務(wù)是否可以加在Controller層的問(wèn)題
這篇文章主要介紹了SpringMVC中事務(wù)是否可以加在Controller層的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
Java實(shí)現(xiàn)多個(gè)文檔合并輸出到一個(gè)文檔
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)多個(gè)文檔合并輸出到一個(gè)文檔的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10

