MySQL查詢不區(qū)分大小寫的兩種解決方式
場景
場景如下,一個簡單的查詢語句;
(mapper方法)
@Select("select * from tb_demo where username = #{username} ")
DemoDTO selectByUsername(String username);
(單元測試)
@Test
public void testSelectByUsername() {
String username = "WangWu";
DemoDTO demoDTO = demoMapper.selectByUsername(username);
System.out.println(demoDTO);
}
數(shù)據(jù)庫數(shù)據(jù),如下:

查詢結果,沒有區(qū)分大小寫,wangwu的記錄被查出來了;

解決
解決方式有兩種,如下:
方法一:更換數(shù)據(jù)庫字符集
在前面的demo中,數(shù)據(jù)庫字符集是:utf8mb4_general_ci,表的字符集:utf8mb4_general_ci,ci,意思是case insensitive,大小寫不敏感,不區(qū)分大小寫。
可以考慮更改為 utf8mb4_bin,但是博主嘗試修改現(xiàn)有數(shù)據(jù)庫的字符集,還是不行,只有在創(chuàng)建表的時候就指定才行。故在以后創(chuàng)建數(shù)據(jù)庫選定字符集時,需考慮業(yè)務是否有區(qū)分大小寫的場景。
方法二:修改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);
}
查詢結果:

總結
本文介紹了在MySQL中,解決查詢不區(qū)分大小寫的兩種方式
到此這篇關于MySQL查詢不區(qū)分大小寫的兩種解決方式的文章就介紹到這了,更多相關MySQL查詢不區(qū)分大小寫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
win2008下mysql8.0.11升級mysql8.0.17版本詳細步驟
這篇文章主要為大家詳細介紹了win2008下mysql8.0.11升級mysql8.0.17版本詳細步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08
win10下安裝mysql8.0.23 及 “服務沒有響應控制功能”問題解決辦法
這篇文章主要介紹了win10下安裝mysql8.0.23 及 “服務沒有響應控制功能”問題解決辦法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03

