做一個簡單的如下的連表查詢,居然直接提示錯誤,居然是字符集不一致的問題,本文記錄一下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 字符集連表異常內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- MySql表、字段、庫的字符集修改及查看方法
- mysql字符集和校對規則(Mysql校對集)
- mysql修改數據庫編碼(數據庫字符集)和表的字符編碼的方法
- 深入Mysql字符集設置分析
- 修改mysql默認字符集的兩種方法詳細解析
- Mysql5 字符集編碼問題解決