Mysql數(shù)據(jù)庫亂碼問題的對應(yīng)方式
MySQL中數(shù)據(jù)庫亂碼一般進行字符集的設(shè)定即可,但是亂碼可以出現(xiàn)在各個階段,所以這篇文章整理一下亂碼出現(xiàn)的各個階段以及對應(yīng)方法。
建庫/建表時添加charset設(shè)定
建庫
CREATE DATABASE 數(shù)據(jù)庫名稱 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
建表
create table 表名(字段構(gòu)成詳細列表信息) default charset=utf8;
客戶端顯示
locale
確認locale設(shè)定是否為UTF8方式,一般服務(wù)器端沒有問題,僅在客戶端存在問題?;蛘咭徊糠挚蛻舳擞袉栴},往往就是客戶端顯示設(shè)定存在問題。
確認命令:locale
mysql設(shè)定
使用show variables like ‘%character%'進行確認,一般修改character_set_database和character_set_server可以僅在當前session修改設(shè)定
使用mysql命令可以進行session范圍內(nèi)的字符集設(shè)定
確認命令(mysql):show variables like '%character%'
局部設(shè)定
僅在當前session起作用,設(shè)定方式為:
set character_set_database=utf8
全局設(shè)定
多個session起作用的設(shè)定方式為:
set global character_set_database=utf8
當然session方式會再數(shù)據(jù)庫重啟后失效,需要持久化保存,同樣的設(shè)定要設(shè)定到mysql的配置文件my.cnf中即可.
這樣在創(chuàng)建數(shù)據(jù)庫或者創(chuàng)建數(shù)據(jù)庫表的時候缺省就是指定的utf8了
如果是純粹的顯示問題,很多時候還有可能是由于character_set_results設(shè)定顯示的。
使用show variables like ‘%character%'進行確認,如果設(shè)定不正確,可以使用如下方式解決
set character_set_results='utf8';
數(shù)據(jù)庫數(shù)據(jù)導(dǎo)出
一般使用mysqldump進行數(shù)據(jù)庫導(dǎo)出會使用如下命令
mysqldump -u用戶名 -p用戶密碼 數(shù)據(jù)庫名稱 >mysqlbackup.sql
如果出現(xiàn)亂碼,可以實現(xiàn)添加如下Option
mysqldump -u用戶名 -p用戶密碼 --default-character-set=utf8 數(shù)據(jù)庫名稱 >mysqlbackup.sql
如果含有blob類型,則需要使用hex-blob選項進行mysqldump導(dǎo)出
mysqldump -u用戶名 -p用戶密碼 --hex-blob 數(shù)據(jù)庫名稱 >mysqlbackup.sql
數(shù)據(jù)庫數(shù)據(jù)導(dǎo)入
導(dǎo)入的時候如果出現(xiàn)問題,也可考慮添加字符級的設(shè)定
mysql -u用戶名 -p用戶密碼 --default-character-set=utf8 數(shù)據(jù)庫名稱 <mysqlbackup.sql
也可使用如下方式,導(dǎo)入之前執(zhí)行如下命令
set names utf8;
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
MySQL 不用存儲過程循環(huán)插入數(shù)據(jù)的方法
在MySQL中,使用INSERT INTO VALUES語句可以一次性插入多行數(shù)據(jù),提高插入效率,還可通過Python的pymysql庫生成和執(zhí)行插入語句,這不僅減少了操作時間,還提高了代碼的簡潔性和執(zhí)行效率2024-09-09
MySQL對數(shù)據(jù)表已有表進行分區(qū)表的實現(xiàn)
本文主要介紹對現(xiàn)有的一個表進行創(chuàng)建分區(qū)表,并把數(shù)據(jù)遷移到新表,可以按時間來分區(qū),具有一定的參考價值,感興趣的可以了解一下2021-10-10
mysql中decimal數(shù)據(jù)類型小數(shù)位填充問題詳解
這篇文章主要介紹了mysql中decimal數(shù)據(jù)類型小數(shù)位填充問題詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Mysql中DATEDIFF函數(shù)的基礎(chǔ)語法及練習(xí)案例
Datediff函數(shù),最大的作用就是計算日期差,能計算兩個格式相同的日期之間的差值,下面這篇文章主要給大家介紹了關(guān)于Mysql中DATEDIFF函數(shù)的基礎(chǔ)語法及練習(xí)案例?的相關(guān)資料,需要的朋友可以參考下2022-09-09

