在创建表是,如果字段类型是字符串varchar,则该字段默认的字符集排序规则为utf8mb4_general_ci,也就是说在查询匹配时不区分大小写,例如where name = 'A' 时,会把 A、a 都查出来。
如果要在查询时区分大小写,则把字符集排序规则改为utf8mb4_bin。
ALTER TABLE test MODIFY COLUMN name VARCHAR(20) COLLATE utf8mb4_bin;
这样调整后,在查询时,就会区分大小写。
总结:
在 MySQL 中,utf8mb4_bin 与 utf8mb4_general_ci 均属于 utf8mb4 字符集的排序规则,二者在数据存储上完全一致,都会原样保存大小写、重音等字符差异,不会自动转换或统一格式。
核心区别体现在比较与查询行为:
utf8mb4_bin 按字符二进制编码比较,严格区分大小写、全半角及重音符号,适合密码、唯一编码等需要精确匹配的场景;
而 utf8mb4_general_ci 为不区分大小写的通用排序规则,在查询匹配时会忽略大小写差异,输入 A 可同时匹配到 A 和 a,更适用于普通文本、搜索、用户名等常规业务场景,也是 MySQL 早期版本中 utf8mb4 的默认排序规则。