mysql的查询默认是不区分大小写的。
看个例子:
可以看到使用如下语句,查询到了同一条记录。
select * from tba where name = 'test'; select * from tba where name = 'TEST';
mysql的表查询大小写是否敏感,取决于字段的collate设置。
我们看下这张表的charset和collate。
charset是utf8,而utf8的默认collate规则是utf8_general_ci。(可通过show charset命令查看。)
*_ci的含义是case insensitive,即不区分大小写。
如果我们想使查询区分大小写。有两种方法:
1、查询条件前binary;
mysql>?select?*?from?tba?where?binary?name?=?'test';
+----+------+-----+------------+
|?id?|?name?|?age?|?addtime????|
+----+------+-----+------------+
|??1?|?test?|??12?|?4294967295?|
+----+------+-----+------------+
1?row?in?set?(0.00?sec)
mysql>??select?*?from?tba?where?binary?name?=?'TEST';
Empty?set?(0.00?sec)
2、可以通过修改字段的collate为utf8_bin;
utf8_bin表示将字符串中的每一个字符用二进制数据存储,区分大小写。
ALTER?TABLE?tba?MODIFY?COLUMN?name?VARCHAR(25)?CHARACTER??SET?utf8?COLLATE?utf8_bin;
mysql>?ALTER?TABLE?tba?MODIFY?COLUMN?name?VARCHAR(20)?CHARACTER??SET?utf8?COLLATE?utf8_bin;
Query?OK,?2?rows?affected?(0.04?sec)
Records:?2??Duplicates:?0??Warnings:?0
mysql>?select?*?from?tba?where?name?=?'test';
+----+------+-----+------------+
|?id?|?name?|?age?|?addtime????|
+----+------+-----+------------+
|??1?|?test?|??12?|?4294967295?|
+----+------+-----+------------+
1?row?in?set?(0.00?sec)
mysql>?select?*?from?tba?where?name?=?'TEST';
Empty?set?(0.00?sec)
|