亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2021年01月26日 14:52:17   作者:MySQL技術(shù)  
這篇文章主要介紹了MySQL修改字符集的方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下

前言:

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

1. utf8 和 utf8mb4 字符集介紹

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

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

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

2. 修改字符集方法

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

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

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

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

首先應(yīng)該修改系統(tǒng)字符集參數(shù),這樣以后創(chuàng)建的庫(kù)表默認(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ù)庫(kù)字符集

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

# 設(shè)置數(shù)據(jù)庫(kù)字符集編碼
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)

修改表及字段字符集

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

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

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

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

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

3. 一些建議

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

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

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

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

相關(guān)文章

  • mysql中RAND()隨便查詢記錄效率問(wèn)題和解決辦法分享

    mysql中RAND()隨便查詢記錄效率問(wèn)題和解決辦法分享

    在我們做開(kāi)發(fā)的中效率一直是個(gè)問(wèn)題,特別是對(duì)于很多大數(shù)據(jù)量操作,今天我們碰到一個(gè)要隨機(jī)查詢數(shù)據(jù),一開(kāi)始我們可能想到最簡(jiǎn)單的order by rand() 來(lái)操作但效率不敢恭維啊
    2012-04-04
  • windows下忘記MySQL密碼的修改方法

    windows下忘記MySQL密碼的修改方法

    這篇文章主要介紹了windows下忘記MySQL密碼的修改方法,需要的朋友可以參考下
    2014-03-03
  • MySQL防止delete命令刪除數(shù)據(jù)的兩種方法

    MySQL防止delete命令刪除數(shù)據(jù)的兩種方法

    在sql中刪除數(shù)據(jù)庫(kù)中記錄我們會(huì)使用到delete命令,這樣如果不小心給刪除了很難恢復(fù)了,下面我來(lái)總結(jié)一些刪除數(shù)據(jù)但是不在數(shù)據(jù)庫(kù)刪除的方法,有需要的朋友可以參考一下
    2013-08-08
  • 使用MySQL唯一索引的注意事項(xiàng)及說(shuō)明

    使用MySQL唯一索引的注意事項(xiàng)及說(shuō)明

    這篇文章主要介紹了使用MySQL唯一索引的注意事項(xiàng)及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • MySQL中order by的使用詳情

    MySQL中order by的使用詳情

    在使用select語(yǔ)句時(shí)可以結(jié)合order by對(duì)查詢的數(shù)據(jù)進(jìn)行排序。如果不使用order by默認(rèn)情況下MySQL返回的數(shù)據(jù)集,與它在底層表中的順序相同,可能與你添加數(shù)據(jù)到表中的順序一致,也可能不一致,如果希望得到的數(shù)據(jù)有順序,就該明確排序方式,下面詳細(xì)內(nèi)容需要的朋友可以參考一下
    2021-11-11
  • MySQL定時(shí)器開(kāi)啟、調(diào)用實(shí)現(xiàn)代碼

    MySQL定時(shí)器開(kāi)啟、調(diào)用實(shí)現(xiàn)代碼

    有些新手朋友對(duì)MySQL定時(shí)器開(kāi)啟、調(diào)用不是很熟悉,本人整理測(cè)試一些,拿出來(lái)和大家分享一下,希望可以幫助你們
    2012-12-12
  • 圖文詳解Mysql索引的最左前綴原則

    圖文詳解Mysql索引的最左前綴原則

    最左前綴原則是發(fā)生在復(fù)合索引上的,只有復(fù)合索引才會(huì)有所謂的左和右之分,下面這篇文章主要給大家介紹了關(guān)于Mysql索引的最左前綴原則的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • Mybatis的where標(biāo)簽使用總結(jié)梳理

    Mybatis的where標(biāo)簽使用總結(jié)梳理

    這篇文章主要介紹了Mybatis的where標(biāo)簽使用總結(jié)梳理,文章通過(guò)將Mybatis中where標(biāo)簽的基本使用形式展開(kāi)where標(biāo)簽小技巧以及容易踩到的坑進(jìn)行總結(jié)梳理,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • mysql use命令選擇數(shù)據(jù)庫(kù)詳解

    mysql use命令選擇數(shù)據(jù)庫(kù)詳解

    這篇文章主要介紹了mysql 使用use命令選擇數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • mysql通過(guò)find_in_set()函數(shù)實(shí)現(xiàn)where in()順序排序

    mysql通過(guò)find_in_set()函數(shù)實(shí)現(xiàn)where in()順序排序

    這篇文章主要介紹了mysql通過(guò)find_in_set()函數(shù)實(shí)現(xiàn)where in()順序排序的相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10

最新評(píng)論