目錄
2.2、解決方案二 可以修改該字段的collation 爲 binary
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屬性是指定列字符集的二元 校對規則的簡寫。排序和比較基於數值字符值。因此也就自然區分了大小寫。