今天我遇到了一個(gè)讓我十分煩躁的問(wèn)題:我的MySQL數(shù)據(jù)庫(kù)全部亂碼了!
這是一種相當(dāng)不幸的情況,因?yàn)閮?chǔ)存在數(shù)據(jù)庫(kù)中的所有數(shù)據(jù)都是無(wú)法正常讀取的。我在網(wǎng)上搜索了一些解決方案,但大多數(shù)都不能解決我的問(wèn)題。
SHOW VARIABLES LIKE 'char%';
我嘗試了一些命令,例如上面的命令,但是結(jié)果看起來(lái)并不是很有用。我猜測(cè)這可能是由于字符集設(shè)置不正確導(dǎo)致的。我試圖將字符集改為utf8mb4,但這似乎并沒(méi)有奏效。
SET NAMES utf8mb4; ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
最終,我發(fā)現(xiàn)自己犯了一個(gè)低級(jí)錯(cuò)誤:我在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)沒(méi)有指定正確的字符集!因此,我現(xiàn)在必須重新創(chuàng)建數(shù)據(jù)庫(kù)并確保正確設(shè)置字符集,并將現(xiàn)有數(shù)據(jù)轉(zhuǎn)換為正確的字符集。這樣做需要一些時(shí)間,但是在解決這個(gè)問(wèn)題后,我再也不會(huì)遇到這種情況了。