MySQL 中 utf8mb4_bin 与 utf8mb4_general_ci 区别

在创建表是,如果字段类型是字符串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 的默认排序规则。

相关推荐
GBASE6 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr16 小时前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满8782 天前
5.Mysql事务隔离级别与锁机制
mysql
笃行3502 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3502 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3502 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H2 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql