写点什么

SQL 报了一个不常见的错误,让新来的实习生懵了

  • 2022 年 6 月 27 日
  • 本文字数:1162 字

    阅读完需:约 4 分钟

SQL报了一个不常见的错误,让新来的实习生懵了

本文分享自华为云社区《记一次mysql关联查询格式冲突问题【五月04】》,作者: KevinQ 。

问题起源


作为 CRUD 程序员,最常用的功能当然是数据库查询了。


前些天一个很简单的 SQL 报了一个不常见的错误:


Illegal mix of collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_unicode_ci,IMPLICIT) for operation '='
复制代码


今天我们就来看看 mysql 的 utf8mb4 的两种格式问题,以及如何解决这个问题?

mysql 的 utf8 格式与排序规则

字符集 uft8 与 uft8mb4


在 mysql 中创建表并添加字段的时候,想选 utf8 字符集时会有两个选择:


  1. utf8

  2. utf8mb4


这两个有什么区别呢?


MySQL 是在 5.5.3 之后才有 utf8mb4 的字符集可选,mb4 的意思是:Most Bytes 4,可以兼容 unicode。

而 utf8 最多支持 3 个字节,比如 3 个字节的 uft8 无法支持 Emoji 表情和不常用的汉字,以及任何新增的 Unicode 字符等,因此才引入了 uft8mb4。

排序规则


我们这次的问题是排序规则冲突引起的:


查询语句:


SELECT * FROM table1 t1 left join table2 on t1.username = t2.username
复制代码


关联字段的编码字符集均为 utf8mb4,但是 t1.username 的排序规则是 utf8mb4_general_ci,而 t2.username 的排序规则是 utf8mb4_unicode_ci。


两种排序规则的区别与特点是什么呢?

特点


utf8mb4_unicode_ci 是基于标准的 Unicode 来排序和比较,即能够支持所有 Unicode 字符的精确排序;

而 utf8mb4_general_ci 没有实现 Unicode 排序规则,在遇到特殊字符时,排序可能不同。

区别


也因此,uft8mb4_general_ci 相比 utf8mb4_unicode_ci,前者的准确性虽然打了折扣,但是比较和排序执行的速度更快,并且,通常遇到特殊字符的顺序并不重要。

排序规则不兼容的解决方案


在 mysql 中,排序规则不兼容的解决方案有两种:


1、第一种,修改表字段的格式一致。


即修改表的排序规则统一为 utf8mb4_unicode_ci,或者另一种。官方更推荐使用 utf8mb4_unicode_ci 的排序规则,借用 StackOverflow 上的一段话:


There is almost certainly no reason to use utf8mb4_general_ci anymore, as we have left behind the point where CPU speed is low enough that the performance difference would be important. Your database will almost certainly be limited by other bottlenecks than this.


大概意思是说,当前 CPU 的运行速度已经快到可以让我们不再将此排序作为一个考虑参数,而更应该开了其他开销。


2、另一种方式则是借助关键字,COLLATE


通过 COLLATE 属性,可以指定列的排序和比较方式。


我们在使用时,将它放在关联查询需要修改排序规则的地方:


SELECT	u.guidFROM	`test`  tLEFT JOIN user u ON u.guid = t.guid COLLATE utf8mb4_unicode_ciWHERE t.state = 1
复制代码


如此,使用 COLLATE 属性,可以让使用不同排序规则的字段进行关联查询。


但是,经过测试,这样会减慢 SQL 查询的速度。


具体采用哪种方式,需要细细考量。


点击关注,第一时间了解华为云新鲜技术~

发布于: 刚刚阅读数: 3
用户头像

提供全面深入的云计算技术干货 2020.07.14 加入

华为云开发者社区,提供全面深入的云计算前景分析、丰富的技术干货、程序样例,分享华为云前沿资讯动态,方便开发者快速成长与发展,欢迎提问、互动,多方位了解云计算! 传送门:https://bbs.huaweicloud.com/

评论

发布
暂无评论
SQL报了一个不常见的错误,让新来的实习生懵了_数据库_华为云开发者联盟_InfoQ写作社区