纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

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

一灰灰   2021-09-10 我要评论
想了解Mysql 字符集不一致导致连表异常的解决的相关内容吗一灰灰在本文为您仔细讲解Mysql 字符集连表异常的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Mysql,字符集连表异常,Mysql,字符集不一致下面大家一起来学习吧

做一个简单的如下的连表查询居然直接提示错误居然是字符集不一致的问题本文记录一下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: 二进制存储大小写敏感

相关文章

猜您喜欢

网友评论

Copyright 2020 www.fresh-weather.com 【世纪下载站】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式