首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Mysql Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operat

Mysql Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operat

作者头像
WindWant
发布2020-09-11 10:57:09
发布2020-09-11 10:57:09
1.3K0
举报
文章被收录于专栏:后端码事后端码事

MySQL字符串比较bug:

代码语言:javascript
复制
select * from table_a a left join table_b b on a.field_a = b.field_b

error:

代码语言:javascript
复制
Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '='

cause:两表编码方式不一致。

resolve:将比较等式的一边进行字符串转换,如:“CONVERT(a.field_a USING utf8) COLLATE utf8_unicode_ci

代码语言:javascript
复制
select * from table_a a left join table_b b on CONVERT(a.field_a USING utf8) COLLATE utf8_unicode_ci = b.field_b

注:utf8_general_ci:校对速度快,准确度差。

utf8_unicode_ci:准确度高,校对速度慢。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-11-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档