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 的默认排序规则。

相关推荐
HalvmånEver2 小时前
MySQL表的约束(二)
java·数据库·mysql
2301_773553622 小时前
如何在登录界面添加自定义背景图片_Login CSS覆盖修改
jvm·数据库·python
cyber_两只龙宝2 小时前
【Oracle】Oracle之SQL的集合运算符
linux·运维·数据库·sql·云原生·oracle
m0_493934532 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
m0_617881422 小时前
如何优雅处理SQL存储过程异常_使用TRY-CATCH块机制
jvm·数据库·python
步辞2 小时前
如何用SQL实现分组内前N个百分比筛选_窗口函数应用
jvm·数据库·python
m0_684501982 小时前
PySpark中高效展开嵌套数组:避免笛卡尔爆炸的正确实践
jvm·数据库·python
zdzx auvu2 小时前
MySQL 函数
数据库·mysql
qq_372906932 小时前
Layui如何实现表格内部的图片点击后进入相册轮播模式
jvm·数据库·python