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); }
數據庫數據,如下:
查詢結果,沒有區(qū)分大小寫,wangwu的記錄被查出來了;
解決
解決方式有兩種,如下:
方法一:更換數據庫字符集
在前面的demo中,數據庫字符集是:utf8mb4_general_ci,表的字符集:utf8mb4_general_ci,ci,意思是case insensitive,大小寫不敏感,不區(qū)分大小寫。
可以考慮更改為 utf8mb4_bin,但是博主嘗試修改現有數據庫的字符集,還是不行,只有在創(chuàng)建表的時候就指定才行。故在以后創(chuàng)建數據庫選定字符集時,需考慮業(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ū)分大小寫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
win2008下mysql8.0.11升級mysql8.0.17版本詳細步驟
這篇文章主要為大家詳細介紹了win2008下mysql8.0.11升級mysql8.0.17版本詳細步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-08-08win10下安裝mysql8.0.23 及 “服務沒有響應控制功能”問題解決辦法
這篇文章主要介紹了win10下安裝mysql8.0.23 及 “服務沒有響應控制功能”問題解決辦法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03