mysql報(bào)錯(cuò) Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for o...

今天有個(gè)SQL執(zhí)行不了,通過(guò)錯(cuò)誤輸出查到了問(wèn)題,大致SQL如下:

SELECT * FROM `table` WHERE `field1`=`filed2`

這個(gè)SQL看起來(lái)是一點(diǎn)錯(cuò)誤都沒(méi)有,但是缺爆出了下面這個(gè)錯(cuò)誤:

Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '='

意思就是編碼不一致不能用“=” 運(yùn)算符。那怎么辦呢。。。還用說(shuō)就是轉(zhuǎn)換編碼了,還好MySQL也有相關(guān)的函數(shù)。

CONVERT(table-colum USING utf8) COLLATE utf8_unicode_ci

比如是field1編碼是utf8_unicode_ci,filed2編碼是utf8_general_ci那么就會(huì)出現(xiàn),那么SQL語(yǔ)句應(yīng)該修改成這樣子。

SELECT * FROM `table` WHERE `field1`=CONVERT(`filed2` USING utf8) COLLATE utf8_unicode_ci

這樣編碼就統(tǒng)一了,不過(guò)這個(gè)只是臨時(shí)解決。最終還是根解決最好,直接修改字段的本身編碼。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容