主頁 > 知識庫 > MySQL修改字符集的實(shí)戰(zhàn)教程

MySQL修改字符集的實(shí)戰(zhàn)教程

熱門標(biāo)簽:常州電銷外呼系統(tǒng)一般多少錢 天智外呼系統(tǒng) 福州呼叫中心外呼系統(tǒng)哪家好 北京人工外呼系統(tǒng)價錢 房產(chǎn)智能外呼系統(tǒng)品牌 地圖標(biāo)注被騙三百怎么辦 云南語音外呼系統(tǒng)平臺 400電話鄭州申請 沃克斯電梯外呼線路圖

前言:

在 MySQL 中,系統(tǒng)支持諸多字符集,不同字符集之間也略有區(qū)別。目前最常用的字符集應(yīng)該是 utf8 和 utf8mb4 了,相比于 utf8 ,utf8mb4 支持存儲 emoji 表情,使用范圍更廣。本篇文章將會介紹 utf8 修改成 utf8mb4 字符集的方法。

1. utf8 和 utf8mb4 字符集介紹

字符(Character)是各種文字和符號的總稱,包括各國家文字、標(biāo)點(diǎn)符號、圖形符號、數(shù)字等。字符集(Character set)是多個字符的集合。

MySQL 中字符集可以作用于四個級別,分別是:服務(wù)器級別、數(shù)據(jù)庫級別、表級別、列級別。服務(wù)器級別的比較規(guī)則由 character_set_server 參數(shù)控制,如果創(chuàng)建數(shù)據(jù)庫、表、列時沒有顯式的指定字符集,則會繼承上一級的字符集。

MySQL 5.7 及之前版本默認(rèn)的字符集是 latin1 ,MySQL 8.0 版本默認(rèn)的字符集是 utf8mb4 。不過使用 latin1 容易導(dǎo)致亂碼,所以還是 utf8 和 utf8mb4 用途最廣泛。utf8 其實(shí)是 utf8mb3 的別名,只使用 1~3 個字節(jié)表示字符。utf8mb4 使用 1~4 個字節(jié)表示字符,能夠存儲更多的 emoji 表情及任何新增的 Unicode 字符。utf8mb4 兼容 utf8 ,且比 utf8 能表示更多的字符,是 utf8 字符集的超集。所以現(xiàn)在一些新的業(yè)務(wù)建議將數(shù)據(jù)庫的字符集設(shè)置為 utf8mb4 ,特別是有表情存儲需求時。

2. 修改字符集方法

目前的互聯(lián)網(wǎng)業(yè)務(wù)對 emoji 表情存儲的需求越來越多,比如昵稱、評論內(nèi)容等都要支持表情符號,這個時候如果數(shù)據(jù)庫字段用的是 utf8 字符集,則會報(bào)如下錯誤:

  java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x95\xF0\x9F...' for    column…………

為了業(yè)務(wù)需求,我們需要將數(shù)據(jù)庫字符集改為 utf8mb4 ,好在 utf8mb4 是 utf8 的超集,除了將編碼改為 utf8mb4 外不需要做其他轉(zhuǎn)換。這里簡單講下修改方法。

系統(tǒng)參數(shù)修改

首先應(yīng)該修改系統(tǒng)字符集參數(shù),這樣以后創(chuàng)建的庫表默認(rèn)字符集就是 utf8mb4 了。找到配置文件,添加或修改以下參數(shù):

vi /etc/my.cnf

[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
skip-character-set-client-handshake
#忽略應(yīng)用連接自己設(shè)置的字符編碼,保持與全局設(shè)置一致
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4

修改數(shù)據(jù)庫字符集

對于已經(jīng)創(chuàng)建的數(shù)據(jù)庫,如果原來是 utf8 字符集,則可以這么修改:

# 設(shè)置數(shù)據(jù)庫字符集編碼
ALTER DATABASE `dbname` CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

# 示例
mysql> show create database testdb;
+----------+-----------------------------------------------------------------+
| Database | Create Database             |
+----------+-----------------------------------------------------------------+
| testdb | CREATE DATABASE `testdb` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+-----------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> alter database `testdb` CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
Query OK, 1 row affected (0.01 sec)

mysql> show create database testdb;
+----------+--------------------------------------------------------------------+
| Database | Create Database             |
+----------+--------------------------------------------------------------------+
| testdb | CREATE DATABASE `testdb` /*!40100 DEFAULT CHARACTER SET utf8mb4 */ |
+----------+--------------------------------------------------------------------+
1 row in set (0.00 sec)

修改表及字段字符集

同樣的,對于已經(jīng)創(chuàng)建的表,修改全局及數(shù)據(jù)庫的字符集并不會影響原表及字段的字符集。原有的 utf8 表可以采用如下方法修改:

# 修改表字符集
alter table `tb_name` default character set utf8mb4;

# 修改某字段字符集
alter table `tb_name` modify col_name varchar(20) character set utf8mb4;

# 同時修改表及字段字符集
alter table `tb_name` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

# 如果某個庫里面表比較多 可以拼接出要執(zhí)行的批量修改語句
SELECT
 CONCAT( 'ALTER TABLE ', TABLE_NAME, ' CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;' ) 
FROM
 information_schema.`TABLES` 
WHERE
 TABLE_SCHEMA = 'testdb';

3. 一些建議

看起來修改方法挺簡單,不過對于生產(chǎn)環(huán)境還是要格外小心。特別是修改字段字符集時,會加鎖,阻止寫操作,對于大表執(zhí)行下來也是很慢的,可能對線上業(yè)務(wù)造成影響。

如果你的數(shù)據(jù)庫比較小,用以上方法應(yīng)該問題不大。對于線上環(huán)境,若要修改字符集,一定要做好評估,最好可以在業(yè)務(wù)低峰期停機(jī)修改,修改前一定要先備份。若無停機(jī)時間,可以考慮先在備庫修改,然后再主備切換,不過這樣做會更麻煩。

有條件的話也可以再準(zhǔn)備一個空實(shí)例,先導(dǎo)入表結(jié)構(gòu),改成 utf8mb4 字符集后再導(dǎo)入數(shù)據(jù)。這也是一種方法,不過也可能需要停機(jī)切換。

以上就是MySQL修改字符集的方法的詳細(xì)內(nèi)容,更多關(guān)于MySQL修改字符集的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • mysql字符集和數(shù)據(jù)庫引擎修改方法分享
  • MySQL查看與修改字符集的方法實(shí)例教程
  • mysql 啟動1067錯誤及修改字符集重啟之后復(fù)原無效問題
  • Linux下MySQL 5.5/5.6的修改字符集編碼為UTF8的方法
  • Mysql數(shù)據(jù)庫支持的存儲引擎對比
  • 基于 Mysql 實(shí)現(xiàn)一個簡易版搜索引擎
  • Mysql中存儲引擎的區(qū)別及比較
  • MySQL 學(xué)習(xí)總結(jié) 之 初步了解 InnoDB 存儲引擎的架構(gòu)設(shè)計(jì)
  • MySQL修改默認(rèn)引擎和字符集詳情

標(biāo)簽:徐州 黔東 沈陽 珠海 移動 鹽城 沈陽 拉薩

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL修改字符集的實(shí)戰(zhàn)教程》,本文關(guān)鍵詞  MySQL,修改,字符集,的,實(shí)戰(zhàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL修改字符集的實(shí)戰(zhàn)教程》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL修改字符集的實(shí)戰(zhàn)教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章