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. 解決方法
先來看上面這個問題的解決方法,最容易想到的就是統(tǒng)一兩張表的字符集,要么都是utf8mb4_general_ci,要么就都是utf8mb4_unicode_ci,統(tǒng)一一下這個問題就自然解決了
如果我不想修改表的字符集呢?畢竟生產(chǎn)環(huán)境下,做這種操作還是有風險的,下面是一種不太優(yōu)雅的解決方法
在字段后面指定字符集(可以全部都指定為utf8mb4_general_ci 當然也可以全部指定為 utf8mb4_unicode_ci, 根據(jù)實際需要進行處理即可)
select a.id, b.id from tt as a, t2 as b where a.xx = b.xx collate utf8mb4_general_ci
2. mysql字符集
字符集
對于國內(nèi)的小伙伴,一般而言我們常見的字符集有下面三種
- gbk: 兩字節(jié)
- utf8: 三個字節(jié)
- utf8mb4: 四個字節(jié)
而mysql實際支持的就比較多了,可以通過show charset;進行查詢
校驗規(guī)則
在實際的case中,經(jīng)常會看到下面幾種
- utf8_bin
- utf8mb4_unicode_ci
- utf8mb4_general_ci
- latin1_general_cs
當然我們也可以通過 show collation;查看所支持的校驗規(guī)則
請注意上面的寫法
- ci: case insensitive的縮寫 大小寫不敏感
- cs: case sensitive 大小寫敏感
- bin: 二進制存儲,大小寫敏感
到此這篇關(guān)于Mysql 字符集不一致導致連表異常的解決的文章就介紹到這了,更多相關(guān)Mysql 字符集連表異常內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql 5.7.17 以及workbench安裝配置圖文教程
這篇文章主要為大家詳細介紹了mysql 5.7.17 以及workbench安裝配置圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-06-06SQL NULL值的定義測試處理空數(shù)據(jù)及SQL?UPDATE語句使用詳解
這篇文章主要為大家介紹了SQL NULL值的定義測試處理空數(shù)據(jù)及SQL?UPDATE語句使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11MySQL用戶授權(quán)管理及白名單的實現(xiàn)
MySQL作為一種常用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在權(quán)限管理和用戶認證方面提供了豐富的功能和方案,本文主要介紹了MySQL用戶授權(quán)管理及白名單的實現(xiàn),感興趣的可以了解一下2023-09-09MySQL查詢優(yōu)化:LIMIT 1避免全表掃描提高查詢效率
在某些情況下,如果明知道查詢結(jié)果只有一個,SQL語句中使用LIMIT 1會提高查詢效率,感興趣的朋友可以了解下哈,希望對你優(yōu)化mysql查詢有所幫助2013-04-04利用Prometheus與Grafana對Mysql服務器的性能監(jiān)控詳解
Prometheus是源于 Google Borgmon的一個開源監(jiān)控系統(tǒng),用 Golang開發(fā)。被很多人稱為下一代監(jiān)控系統(tǒng)。Grafana是一個開源的圖表可視化系統(tǒng),簡單說圖表配置比較方便、生成的圖表比較漂亮。下面就介紹了利用Prometheus與Grafana對Mysql服務器性能監(jiān)控的方法。2017-03-03