Mysql 字符集不一致导致连表异常的解决
16lz
2021-12-09
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 '='
在字段后面指定字符集(可以全部都指定为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
- 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: 二进制存储,大小写敏感
更多相关文章
- Android(安卓)全局异常处理(二)
- [置顶] android 捕捉异常
- Android(安卓)异常后如何重启应用
- Android全局异常统一处理
- Android(安卓)webview Not allowed to load local resource异常
- 【Android】java.lang.SecurityException: Permission Denial: s
- Android(安卓)Studio使用过程中遇到的问题(一)-- "value 2"异常解
- Android(安卓)NullPointerException解决方法(空指针异常)
- Android(安卓)代码混淆异常 transformClassesAndResourcesWithPr