mysql如何在已有數(shù)據(jù)庫(kù)上統(tǒng)一字符集
數(shù)據(jù)庫(kù)里面,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是latin1的,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是UTF8,還有部分表,表結(jié)構(gòu)是utf8而數(shù)據(jù)是latin1。
這種奇葩情況,工作了十幾年的我,還是第一次碰到。下面說(shuō)一下,怎么樣字符集統(tǒng)一成utf8
1,建一個(gè)空數(shù)據(jù)庫(kù)
2,把表結(jié)構(gòu)和數(shù)據(jù)是utf8的表導(dǎo)出,然后直接導(dǎo)入到新的數(shù)據(jù)庫(kù)中
3,數(shù)據(jù)表和數(shù)據(jù)都是latin1的表,先導(dǎo)出表結(jié)構(gòu)和數(shù)據(jù),加上--default-character-set=latin1,將導(dǎo)出文件中,latin1改為utf8,在導(dǎo)入到新的數(shù)據(jù)庫(kù)中。
4,表結(jié)構(gòu)是utf8,表數(shù)據(jù)是latin1的,有二種方法:
4.1,先導(dǎo)出表結(jié)構(gòu),導(dǎo)入到新的數(shù)據(jù)庫(kù)中。導(dǎo)出數(shù)據(jù),加上--default-character-set=utf8,因?yàn)楸斫Y(jié)構(gòu)是utf8,表數(shù)據(jù)是latin1,入庫(kù)時(shí)已亂碼。在將數(shù)據(jù)導(dǎo)入到新庫(kù)中。這種方案有缺點(diǎn),--default-character-set=utf8,導(dǎo)出的數(shù)據(jù)可能會(huì)有丟失,導(dǎo)出的數(shù)據(jù),在導(dǎo)入時(shí)可能會(huì)報(bào)錯(cuò)。
4.2,可以通過(guò)binary字符集做中轉(zhuǎn),推薦這種方法
UPDATE user SET user_name = CONVERT(CONVERT(CONVERT(user_name USING latin1) USING binary) USING UTF8);
這種方法,省去了導(dǎo)出導(dǎo)入的麻煩,速度比較快,11w條數(shù)據(jù),差不多5-6秒
數(shù)據(jù)庫(kù)設(shè)計(jì)這塊非常重要,在設(shè)計(jì)數(shù)據(jù)庫(kù)時(shí)一定要考慮清楚。地基不牢,大廈遲早會(huì)倒的。
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信