MySQL查詢不區(qū)分大小寫的兩種解決方式
場(chǎng)景
場(chǎng)景如下,一個(gè)簡(jiǎn)單的查詢語(yǔ)句;
(mapper方法)
@Select("select * from tb_demo where username = #{username} ") DemoDTO selectByUsername(String username);
(單元測(cè)試)
@Test public void testSelectByUsername() { String username = "WangWu"; DemoDTO demoDTO = demoMapper.selectByUsername(username); System.out.println(demoDTO); }
數(shù)據(jù)庫(kù)數(shù)據(jù),如下:
查詢結(jié)果,沒有區(qū)分大小寫,wangwu的記錄被查出來了;
解決
解決方式有兩種,如下:
方法一:更換數(shù)據(jù)庫(kù)字符集
在前面的demo中,數(shù)據(jù)庫(kù)字符集是:utf8mb4_general_ci,表的字符集:utf8mb4_general_ci,ci,意思是case insensitive,大小寫不敏感,不區(qū)分大小寫。
可以考慮更改為 utf8mb4_bin,但是博主嘗試修改現(xiàn)有數(shù)據(jù)庫(kù)的字符集,還是不行,只有在創(chuàng)建表的時(shí)候就指定才行。故在以后創(chuàng)建數(shù)據(jù)庫(kù)選定字符集時(shí),需考慮業(yè)務(wù)是否有區(qū)分大小寫的場(chǎng)景。
方法二:修改SQL
可以在SQL中,指定字符集比較。像上面的SQL,修改如下:
@Select("select * from tb_demo where username = #{username} COLLATE utf8mb4_bin") DemoDTO selectByUsername(String username);
指定用 utf8mb4_bin字符集比較,就能區(qū)分大小寫了,如下:
@Test public void testSelectByUsername() { DemoDTO demoDTO1 = demoMapper.selectByUsername("WangWu"); System.out.println("demoDTO1 = " + demoDTO1); DemoDTO demoDTO2 = demoMapper.selectByUsername("wangwu"); System.out.println("demoDTO2 = " + demoDTO2); }
查詢結(jié)果:
總結(jié)
本文介紹了在MySQL中,解決查詢不區(qū)分大小寫的兩種方式
到此這篇關(guān)于MySQL查詢不區(qū)分大小寫的兩種解決方式的文章就介紹到這了,更多相關(guān)MySQL查詢不區(qū)分大小寫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
win2008下mysql8.0.11升級(jí)mysql8.0.17版本詳細(xì)步驟
這篇文章主要為大家詳細(xì)介紹了win2008下mysql8.0.11升級(jí)mysql8.0.17版本詳細(xì)步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08SQL如何獲取目標(biāo)時(shí)間點(diǎn)或日期的方法實(shí)例
日期獲取在我們?nèi)粘i_發(fā)中經(jīng)常會(huì)遇到,這篇文章主要給大家介紹了關(guān)于SQL如何獲取目標(biāo)時(shí)間點(diǎn)或日期的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10win10下安裝mysql8.0.23 及 “服務(wù)沒有響應(yīng)控制功能”問題解決辦法
這篇文章主要介紹了win10下安裝mysql8.0.23 及 “服務(wù)沒有響應(yīng)控制功能”問題解決辦法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03手把手教你Navicat如何導(dǎo)出Excel格式的表結(jié)構(gòu)
我們?cè)陂_發(fā)中使用數(shù)據(jù)庫(kù)時(shí)往往需要做一些備份之類的,或者需要導(dǎo)出下表結(jié)構(gòu)導(dǎo)入到其他數(shù)據(jù)庫(kù)等,下面這篇文章主要給大家介紹了關(guān)于Navicat如何導(dǎo)出Excel格式的表結(jié)構(gòu)的相關(guān)資料,需要的朋友可以參考下2023-04-04