对于非二进制字符串 ( CHAR
,
VARCHAR
,
TEXT
),字符串搜索使用比较操作数的排序规则。对于二进制字符串 ( BINARY
,
VARBINARY
,
BLOB
),比较使用操作数中字节的数值;这意味着对于字母字符,比较区分大小写。
非二进制字符串和二进制字符串之间的比较被视为二进制字符串的比较。
简单的比较操作(>=, >, =, <,
<=
、排序和分组)基于每个字符的“排序值”。”具有相同排序值的字符被视为相同的字符。例如,如果e
和
é
在给定排序规则中具有相同的排序值,则它们比较相等。
默认字符集和排序规则是
latin1
and
latin1_swedish_ci
,因此默认情况下非二进制字符串比较不区分大小写。这意味着,如果您使用 搜索
,您将获得所有以或
开头的列值
。要使此搜索区分大小写,请确保其中一个操作数具有区分大小写或二进制排序规则。例如,如果要比较都具有
字符集的列和字符串,则可以使用
运算符使任一操作数具有or
排序规则:
col_name
LIKE
'a%'A
a
latin1
COLLATE
latin1_general_cs
latin1_bin
col_name COLLATE latin1_general_cs LIKE 'a%'
col_name LIKE 'a%' COLLATE latin1_general_cs
col_name COLLATE latin1_bin LIKE 'a%'
col_name LIKE 'a%' COLLATE latin1_bin
如果您希望始终以区分大小写的方式处理列,请使用区分大小写或二进制排序规则声明它。请参阅第 13.1.18 节,“CREATE TABLE 语句”。
要使非二进制字符串的区分大小写的比较不区分大小写,请使用COLLATE
命名不区分大小写的排序规则。以下示例中的字符串通常区分大小写,但
COLLATE
将比较更改为不区分大小写:
mysql> SET @s1 = 'MySQL' COLLATE latin1_bin,
-> @s2 = 'mysql' COLLATE latin1_bin;
mysql> SELECT @s1 = @s2;
+-----------+
| @s1 = @s2 |
+-----------+
| 0 |
+-----------+
mysql> SELECT @s1 COLLATE latin1_swedish_ci = @s2;
+-------------------------------------+
| @s1 COLLATE latin1_swedish_ci = @s2 |
+-------------------------------------+
| 1 |
+-------------------------------------+
二进制字符串在比较时区分大小写。要将字符串比较为不区分大小写,请将其转换为非二进制字符串并用于COLLATE
命名不区分大小写的排序规则:
mysql> SET @s = BINARY 'MySQL';
mysql> SELECT @s = 'mysql';
+--------------+
| @s = 'mysql' |
+--------------+
| 0 |
+--------------+
mysql> SELECT CONVERT(@s USING latin1) COLLATE latin1_swedish_ci = 'mysql';
+--------------------------------------------------------------+
| CONVERT(@s USING latin1) COLLATE latin1_swedish_ci = 'mysql' |
+--------------------------------------------------------------+
| 1 |
+--------------------------------------------------------------+
要确定一个值是作为非二进制字符串还是二进制字符串进行比较,请使用该COLLATION()
函数。此示例显示
VERSION()
返回具有不区分大小写排序规则的字符串,因此比较不区分大小写:
mysql> SELECT COLLATION(VERSION());
+----------------------+
| COLLATION(VERSION()) |
+----------------------+
| utf8_general_ci |
+----------------------+
对于二进制字符串,排序规则值为
binary
,因此比较区分大小写。您可能会看到的一个上下文binary
是压缩函数,它通常返回二进制字符串作为一般规则:
mysql> SELECT COLLATION(COMPRESS('x'));
+--------------------------+
| COLLATION(COMPRESS('x')) |
+--------------------------+
| binary |
+--------------------------+
要检查字符串的排序值,
WEIGHT_STRING()
可能会有所帮助。请参阅第 12.8 节,“字符串函数和运算符”。