溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在MySQ中修改字符集

發布時間:2021-01-27 14:52:42 來源:億速云 閱讀:196 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關如何在MySQ中修改字符集,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

1. utf8 和 utf8mb4 字符集介紹

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

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

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

2. 修改字符集方法

目前的互聯網業務對 emoji 表情存儲的需求越來越多,比如昵稱、評論內容等都要支持表情符號,這個時候如果數據庫字段用的是 utf8 字符集,則會報如下錯誤:

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

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

系統參數修改

首先應該修改系統字符集參數,這樣以后創建的庫表默認字符集就是 utf8mb4 了。找到配置文件,添加或修改以下參數:

vi /etc/my.cnf

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

修改數據庫字符集

對于已經創建的數據庫,如果原來是 utf8 字符集,則可以這么修改:

# 設置數據庫字符集編碼
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)

修改表及字段字符集

同樣的,對于已經創建的表,修改全局及數據庫的字符集并不會影響原表及字段的字符集。原有的 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;

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

看完上述內容,你們對如何在MySQ中修改字符集有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女