mysql關(guān)聯(lián)兩張表時(shí)的編碼問題及解決辦法
Mysql關(guān)聯(lián)兩張表時(shí),產(chǎn)生錯(cuò)誤提示Illegal mix of collations
1、先用工具把數(shù)據(jù)庫、兩張表的編碼方式改變
2、這步很重要,需要改變字段的編碼方式。
ALTER TABLE `表名` CHANGE `dev_chancode` `字段` VARCHAR(32) CHARACTER SET gbk NOT NULL;
總結(jié):在建表時(shí)一定注意統(tǒng)一的編碼方式,后續(xù)搞來搞去超級麻煩。
如何解決MySQL表編碼轉(zhuǎn)換問題
- 將待導(dǎo)出的數(shù)據(jù)表的表結(jié)構(gòu)導(dǎo)出(可以用Phpmyadmin、mysqldump等,很簡單就不說了),然后將導(dǎo)出的create table語句的CHARSET=latin1改為CHARSET=utf8,在目標(biāo)庫newdbname中執(zhí)行該create table語句把表結(jié)構(gòu)建好,接下來開始導(dǎo)出-導(dǎo)入數(shù)據(jù)。命令:
- ./mysqldump -d DB_Dig > /usr/local/tmp/tables.sql
- 命令行:進(jìn)入mysql命令行下,mysql -hlocalhost -uroot -p*** dbname
- 執(zhí)行SQL select * from tbname into outfile '/usr/local/tbname.sql';
- 將tbname.sql轉(zhuǎn)碼為utf-8格式,建議使用UltraEditor,可以直接使用該編輯器的'轉(zhuǎn)換->ASCII到UTF-8(Unicode編輯)',或者將文件另存為UTF-8(無BOM)格式
- 在mysql命令行下執(zhí)行語句 set character_set_database=utf8; 注:設(shè)置mysql的環(huán)境變量,這樣mysql在下一步讀取sql文件時(shí)將以utf8的形式去解釋該文件內(nèi)容
- 在mysql命令行下執(zhí)行語句 load data infile 'tbname.sql' into table newdbname.tbname;
以上就是本次介紹的全部知識點(diǎn)內(nèi)容,感謝大家的學(xué)習(xí)和對腳本之家的支持。
- 修改MySQL數(shù)據(jù)庫中表和表中字段的編碼方式的方法
- Mysql數(shù)據(jù)庫編碼問題 (修改數(shù)據(jù)庫,表,字段編碼為utf8)
- mysql修改數(shù)據(jù)庫編碼(數(shù)據(jù)庫字符集)和表的字符編碼的方法
- mysql中數(shù)據(jù)庫與數(shù)據(jù)表編碼格式的查看、創(chuàng)建及修改
- mysql存儲emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
- MySQL中使用SQL語句查看某個(gè)表的編碼方法
- 解決spring-data-jpa mysql建表編碼問題
- 修改MySQL所有表的編碼或修改某個(gè)字段的編碼步驟詳解
相關(guān)文章
登錄MySQL數(shù)據(jù)庫最快幾步(圖文步驟詳解)
當(dāng)?MySQL?服務(wù)開啟后,就可以通過客戶端來登錄?MySQL?數(shù)據(jù)庫了。在?Windows?操作系統(tǒng)下可以使用?DOS?命令登錄數(shù)據(jù)庫,本節(jié)將介紹使用命令方式登錄?MySQL?數(shù)據(jù)庫的方法2023-10-10
mysql建庫時(shí)提示Specified key was too long max key length is 1000
本文將詳細(xì)提供mysql建庫時(shí)提示Specified key was too long max key length is 1000 bytes的問題的解決方法,有需求的朋友可以參考2012-11-11
python 連接數(shù)據(jù)庫mysql解壓版安裝配置及遇到問題
今天學(xué)習(xí)python連接數(shù)據(jù)庫,就想安裝一下mysql數(shù)據(jù)庫,沒想到小小的數(shù)據(jù)庫也遇到了不少挫折,所以我就把自己的安裝過程以及問題寫出來分享給大家,需要的朋友可以參考下2019-06-06
解決MySQL啟動報(bào)錯(cuò):ERROR 2003 (HY000): Can''t connect to MySQL serv
這篇文章主要介紹了解決MySQL啟動報(bào)錯(cuò):ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061),本文解釋了如何解決該問題,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
親手教你怎樣創(chuàng)建一個(gè)簡單的mysql數(shù)據(jù)庫
數(shù)據(jù)庫是存放數(shù)據(jù)的“倉庫”,維基百科對此形象地描述為“電子化文件柜”,這篇文章主要介紹了親手教你怎樣創(chuàng)建一個(gè)簡單的mysql數(shù)據(jù)庫,需要的朋友可以參考下2022-11-11
mysql觸發(fā)器一個(gè)表改變另一個(gè)表也改變問題
這篇文章主要介紹了mysql觸發(fā)器一個(gè)表改變另一個(gè)表也改變問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08

