日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL修改字符集的實戰教程

瀏覽:24日期:2023-10-06 13:26:05
前言:

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

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: ’xF0x9Fx92x95xF0x9F...’ for column…………

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

系統參數修改

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

vi /etc/my.cnf[mysqld]character-set-server = utf8mb4collation-server = utf8mb4_general_ciskip-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’;3. 一些建議

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

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

有條件的話也可以再準備一個空實例,先導入表結構,改成 utf8mb4 字符集后再導入數據。這也是一種方法,不過也可能需要停機切換。

以上就是MySQL修改字符集的方法的詳細內容,更多關于MySQL修改字符集的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美一区=区三区| 久久国产精品免费一区二区三区 | 99久久婷婷| 欧美不卡视频| 亚洲欧美日韩国产综合精品二区| 国产精品毛片在线| 日本综合精品一区| 国产精品多人| 欧美1区二区| 一区二区精品伦理...| 日韩欧美一区二区三区免费看| 久久久久免费| 91久久视频| 日本一区二区三区中文字幕| 国产欧美日韩在线观看视频| 国产成人黄色| 亚洲欧洲午夜| 国产日韩免费| 国产成人在线中文字幕| 亚洲一级高清| 久久精品 人人爱| 天堂√8在线中文| 国产亚洲在线观看| 日本欧美一区| 天堂av在线| 综合色就爱涩涩涩综合婷婷| 精品一区二区三区免费看| 亚洲国产综合在线看不卡| 免费在线成人网| 久久国产三级精品| 中文字幕在线视频久| 性色一区二区| 久久中文字幕一区二区三区| 欧美日韩国产在线一区| 国产亚洲欧美日韩在线观看一区二区| 亚洲黄色网址| 在线观看亚洲精品福利片| 精品久久一区| 美女尤物久久精品| 麻豆一区二区三区| 一区二区视频欧美| 国产美女亚洲精品7777| 亚洲精品伦理| 亚洲欧美日韩一区在线观看| 日韩av影院| 欧美精品资源| 日韩高清在线不卡| 久久久国产亚洲精品| 91精品国产经典在线观看| 伊人久久大香线蕉av不卡| 国产亚洲精aa在线看| 久久精品一区二区不卡| 国产毛片久久久| 久久狠狠婷婷| 欧美国产不卡| 亚洲精品大全| 91精品一区二区三区综合| 国产欧美午夜| 中文一区一区三区免费在线观 | 日韩二区在线观看| 91精品亚洲| 国产一区二区三区久久| 日韩中文字幕1| 91亚洲人成网污www| 日韩一区二区三免费高清在线观看| 久久精品亚洲人成影院| 免费视频一区二区三区在线观看 | 婷婷精品在线| 婷婷亚洲五月色综合| 精品午夜视频| 国产亚洲精品精品国产亚洲综合| 国产日韩综合| 国产99久久| 久久电影tv| 国产精品嫩草影院在线看| 蜜臀精品久久久久久蜜臀| 日韩一区电影| 老色鬼精品视频在线观看播放| 日韩国产成人精品| 日韩高清不卡在线| 蜜臀91精品一区二区三区| 九九综合九九| 久久婷婷亚洲| 欧美不卡高清一区二区三区| 欧美www视频在线观看| 国产精品15p| 国产精品色在线网站| 国产日韩欧美一区二区三区在线观看| 亚洲婷婷丁香| 妖精视频成人观看www| av亚洲免费| 在线看片不卡| 日韩视频一区| 爽好久久久欧美精品| 国产亚洲网站| 亚洲一区二区成人| 美美哒免费高清在线观看视频一区二区 | 国内在线观看一区二区三区| 国产日本亚洲| 国产日韩欧美三区| 国产精品天天看天天狠| 久久国际精品| 老司机免费视频一区二区三区| 国产精品久久久久久久久久妞妞| 国产精品亚洲产品| 色婷婷成人网| 国产精品久久久久av蜜臀| 免费精品一区| 色爱综合网欧美| 欧美日韩精品一区二区视频| 欧美特黄一区| 免费黄网站欧美| 国产免费av一区二区三区| 久久精品一区二区国产| 成人精品视频| 亚洲国产影院| 午夜亚洲一区| 日韩欧美高清一区二区三区| 日韩视频1区| 国产精品第一国产精品| 久久香蕉网站| 久久亚洲国产| 亚洲一区二区三区久久久| 欧美精品福利| av免费不卡国产观看| 91精品国产调教在线观看 | 久久精品高清| 石原莉奈一区二区三区在线观看| 日本在线观看不卡视频| 欧美激情网址| 成人看片网站| 亚洲香蕉久久| 老司机精品视频在线播放| 中文字幕系列一区| 丝袜a∨在线一区二区三区不卡| 欧美久久香蕉| 久久久久久久久99精品大| 丝袜美腿亚洲一区| 狠狠久久伊人中文字幕| 香蕉国产精品| 91成人精品在线| 欧美成人精品三级网站| 蜜臀av在线播放一区二区三区 | 日韩精品成人| 免费看av不卡| 亚洲综合中文| 国产精品黑丝在线播放| 日韩制服丝袜先锋影音| 欧美激情麻豆| 日韩天堂av| 久久99国产精品视频| 亚洲黄页一区| 激情不卡一区二区三区视频在线| 欧美精品一区二区久久| 国产欧美日韩一级| 亚洲不卡av不卡一区二区| 日韩高清不卡一区| 亚洲欧美一区在线| 国产日产高清欧美一区二区三区| 神马日本精品| 久久av导航| 久久亚洲不卡| 日韩不卡免费高清视频| 久久国产麻豆精品| 国产一区成人| 午夜欧美巨大性欧美巨大| 日韩毛片网站| 激情综合亚洲| 高清久久精品| 国产日产高清欧美一区二区三区| 国产一区二区中文| 国内精品亚洲| 国产精品一区二区三区美女 | 黄色亚洲在线| 午夜影院一区| 精品视频99| 日韩精品一区二区三区免费视频| 欧洲一级精品| 久久精品免费看| 欧美日韩1区| 老牛国产精品一区的观看方式| 亚洲综合电影| 丰满少妇一区| 国产高清视频一区二区| 免播放器亚洲一区| 在线国产一区二区| 神马日本精品| 精品精品久久| 欧美成a人片免费观看久久五月天| 综合欧美精品| 蜜臀av亚洲一区中文字幕| 欧美影院三区| 亚洲成人av观看| 蜜臀久久精品| 成人自拍av| 91精品国产调教在线观看| 国产美女高潮在线观看| 麻豆视频一区二区| 国产精品大片| 国产精品久久久久久久久久妞妞|