MySQL解決字段不區分大小寫

目錄

1、使用場景

2、代碼實現

2.1、解決方案一 可以將查詢條件用binary()括起來

2.2、解決方案二 可以修改該字段的collation 爲 binary

3、總結

4、參考文章


1、使用場景

        最近因爲項目需要,對接公司內部用戶中心;用戶中心因爲等保要求;需要針對用戶名和密碼加強複雜度驗證。於是要求用戶名複雜度6-20位,可以包含大小字母;同時因爲用戶名可以是手機號,所以可能是數字。於是寫了一個正則表達式如下:

用戶名的正則表達式 英文、數字或英文和數字組合;英文不區分大小寫;6-20長度
String pattern = "^[a-zA-Z1-9][a-zA-Z0-9]{5,19}$";

      但是MySQL默認的字段是不區分大小的,下面查詢語句得到的結果是一樣的,如果我們需要進行區分的話可以按照如下方法來做:

select * from table_name where name='abc';

select * from table_name where name='ABC';

2、代碼實現

查詢資料發現需要設置collate(校對) 。 collate規則:

 *_bin: 表示的是binary case sensitive collation,也就是說是區分大小寫的

 *_cs: case sensitive collation,區分大小寫

 *_ci: case insensitive collation,不區分大小寫

2.1、解決方案一 可以將查詢條件用binary()括起來

select * from table_name where binary columnA ='aaa';

2.2、解決方案二 可以修改該字段的collation 爲 binary

alter table tablename modify column columnname varchar(50) binary character set utf8 collate utf8_bin default null;

3、總結

        如果字段區分開始就定義,建議使用第二種解決方案從數據庫字段底層支持。第一種方式如果代碼已經有了很多位置都需要調整和修改代碼。

原理:對於CHAR、VARCHAR和TEXT類型,BINARY屬性可以爲列分配該列字符集的 校對規則。BINARY屬性是指定列字符集的二元 校對規則的簡寫。排序和比較基於數值字符值。因此也就自然區分了大小寫。

4、參考文章

mysql 如何解決字段不區分大小寫的問題

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章