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

相关推荐
Drache_long几秒前
MySQL数据库(故障排除)
数据库·mysql
2303_821287381 分钟前
如何清洗SQL输入数据_使用框架内置的ORM处理数据交互
jvm·数据库·python
清风雅雨2 分钟前
AI编程:OA流程明细表中多个金额字段由整数改为2位小数
数据库·ai编程
菜鸟上路_lbz3 分钟前
sqlserver存储过程查询缓慢锁表分析
数据库·sqlserver
Elastic 中国社区官方博客5 分钟前
在 Elasticsearch 中使用利润率与流行度加权来优化电商搜索
大数据·数据库·elasticsearch·搜索引擎·全文检索
van久33 分钟前
Day32:项目性能优化(EF Core + 分页 + 全异步)
数据库·oracle·性能优化
shaoming37761 小时前
浏览器动作开发:地址栏图标点击事件、弹出页面设计
android·mysql·adb
Dxy12393102161 小时前
Python请求方式介绍:JSON、表单及其他常见数据传输格式
数据库·python·json
环流_3 小时前
Redis中string类型的应用场景
数据库·redis·缓存
倔强的石头_3 小时前
拒绝被复杂报表拖垮!HTAP场景下“标量子查询消除”硬核调优指南
数据库