【MySQL系列】理解 `utf8mb4` 和 `utf8mb4_unicode_ci`

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

博客目录

在现代数据库设计中,字符集和校对规则的选择对于数据的存储、检索和比较至关重要。特别是在处理多语言环境和需要精确匹配的场景时,正确的字符集和校对规则可以确保数据的准确性和一致性。

字符集和校对规则简介

字符集定义了数据库可以存储的字符集合,而校对规则则定义了如何比较这些字符。在 MySQL 等数据库系统中,utf8mb4 是一种常用的字符集,它支持存储任意 Unicode 字符,包括表情符号等。utf8mb4utf8 的超集,可以存储更多的字符,因此成为存储国际化数据的首选。

校对规则(collation)则定义了字符比较的规则,包括大小写敏感性、重音符号的处理等。utf8mb4_unicode_ci 是一个常见的校对规则,其中的 ci 后缀代表"case-insensitive",即不区分大小写。这意味着在比较时,Aa 会被视为相同。

utf8mb4_unicode_ci 的影响

使用 utf8mb4_unicode_ci 校对规则的字段在进行比较时会自动忽略大小写差异。这对于某些应用场景是有利的,比如用户登录时,用户名的比较通常不区分大小写。然而,在需要区分大小写的场景下,这种默认行为可能会导致问题。

例如,考虑一个存储租户 ID(tenantId)的字段,如果使用 utf8mb4_unicode_ci 校对规则,那么查询 SELECT * FROM table_name WHERE tenantId = 'someTenantId';SELECT * FROM table_name WHERE tenantId = 'SomeTenantId'; 会返回相同的结果。这可能不是我们想要的,特别是在处理需要精确匹配的业务逻辑时。

区分大小写的查询

如果需要在查询中区分大小写,可以通过显式指定一个区分大小写的校对规则来实现。例如,utf8mb4_unicode_cs 就是一个区分大小写的校对规则。使用这个校对规则,上述两个查询将返回不同的结果。

sql 复制代码
SELECT * FROM table_name WHERE tenantId COLLATE utf8mb4_unicode_cs = 'SomeTenantId';

这条查询会区分大小写,只有当 tenantId 确切为 SomeTenantId 时才会返回结果。

选择合适的字符集和校对规则

选择合适的字符集和校对规则对于数据库的性能和数据的准确性至关重要。以下是一些选择时需要考虑的因素:

  1. 国际化支持 :如果应用需要支持多种语言,utf8mb4 是一个不错的选择,因为它支持所有 Unicode 字符。

  2. 大小写敏感性 :如果业务逻辑要求区分大小写,那么应该选择一个区分大小写的校对规则,如 utf8mb4_unicode_cs

  3. 性能考虑:不同的校对规则可能会影响查询性能。区分大小写的校对规则通常比不区分大小写的校对规则慢,因为它们需要进行更复杂的比较。

  4. 数据一致性:确保数据库中所有相关字段使用相同的字符集和校对规则,以避免数据不一致的问题。

觉得有用的话点个赞 👍🏻 呗。

❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

相关推荐
白萝卜弟弟9 分钟前
【MySQL】MySQL中的函数之JSON_ARRAY_INSERT
数据库·mysql·json
QQ_1154320311 小时前
基于Java+SpringBoot+Mysql在线简单拍卖竞价拍卖竞拍系统功能设计与实现四
java·spring boot·mysql·毕业设计·毕业源码·竞拍系统·竞拍平台
blammmp1 小时前
MySQL:事务
数据库·mysql
白萝卜弟弟1 小时前
【MySQL】MySQL中的函数之JSON_ARRAY_APPEND
数据库·mysql·json
尘浮生1 小时前
Java项目实战II基于SpringBoot的客户关系管理系统(开发文档+数据库+源码)
java·开发语言·数据库·spring boot·后端·微信小程序·小程序
晚风_END2 小时前
postgresql|数据库开发|python的psycopg2库按指定顺序批量执行SQL文件(可离线化部署)
服务器·开发语言·数据库·python·sql·postgresql·数据库开发
桃园码工2 小时前
2-测试bigcache做进程内缓存 --开源项目obtain_data测试
vscode·mysql·go·postman
晴子呀2 小时前
Redis除了做缓存,还能做什么???
数据库·redis·缓存
sxy1993sxy20182 小时前
数据库和缓存的数据一致性 -20241124
数据库·缓存
hxj..2 小时前
【中间件】Redis
数据库·redis·缓存·中间件