• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Mysql 字符集不一致导致连表异常的解决

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

做一个简单的如下的连表查询,居然直接提示错误,居然是字符集不一致的问题,本文记录一下mysql的字符集类型,以及下面这个问题的解决方案

select a.id, b.id from tt as a, t2 as b where a.xx = b.xx

-- Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT) for operation '='

1. 解决方法

先来看上面这个问题的解决方法,最容易想到的就是统一两张表的字符集,要么都是utf8mb4_general_ci,要么就都是utf8mb4_unicode_ci,统一一下这个问题就自然解决了
如果我不想修改表的字符集呢?毕竟生产环境下,做这种操作还是有风险的,下面是一种不太优雅的解决方法

在字段后面指定字符集(可以全部都指定为utf8mb4_general_ci 当然也可以全部指定为 utf8mb4_unicode_ci, 根据实际需要进行处理即可)

select a.id, b.id from tt as a, t2 as b where a.xx = b.xx collate utf8mb4_general_ci

2. mysql字符集

字符集

对于国内的小伙伴,一般而言我们常见的字符集有下面三种

  • gbk: 两字节
  • utf8: 三个字节
  • utf8mb4: 四个字节

而mysql实际支持的就比较多了,可以通过show charset;进行查询

校验规则

在实际的case中,经常会看到下面几种

  • utf8_bin
  • utf8mb4_unicode_ci
  • utf8mb4_general_ci
  • latin1_general_cs

当然我们也可以通过 show collation;查看所支持的校验规则

请注意上面的写法

  • ci: case insensitive的缩写 大小写不敏感
  • cs: case sensitive 大小写敏感
  • bin: 二进制存储,大小写敏感

到此这篇关于Mysql 字符集不一致导致连表异常的解决的文章就介绍到这了,更多相关Mysql 字符集连表异常内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
redis keys与scan命令的区别说明发布时间:2022-02-10
下一篇:
Redis集群水平扩展、集群中添加以及删除节点的操作发布时间:2022-02-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap