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

相关推荐
素材积累9 小时前
博士后出站来深可申请的项目补贴等
数据库
_1_710 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
basketball61610 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存
李可以量化10 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
汽车仪器仪表相关领域12 小时前
南华 NHAT-610 柴油车排放测试仪 产品详解
数据库·功能测试·汽车·压力测试·可用性测试
我滴老baby13 小时前
工业时序数据实战:基于 DolphinDB 流计算引擎的实现与调优
数据库
睡不醒男孩03082313 小时前
TiDB数据库调研
数据库·tidb
珠***格14 小时前
实操落地|防逆流装置的安装规范、调试标准与故障处置
网络·数据库·人工智能·分布式·能源·边缘计算
Omics Pro14 小时前
3种蛋白结构输入方式!已申报欧洲发明专利
数据库·人工智能·python·机器学习·plotly
itfallrain15 小时前
Spring 构造器循环依赖排查:@RequiredArgsConstructor + @Lazy 到底有没有生效
数据库·python·spring