校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL修改字符集的實戰教程

MySQL修改字符集的實戰教程

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

前言:

在 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: '\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';

3. 一些建議

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

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

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

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

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

標簽:徐州 黔東 沈陽 珠海 移動 鹽城 沈陽 拉薩

巨人網絡通訊聲明:本文標題《MySQL修改字符集的實戰教程》,本文關鍵詞  MySQL,修改,字符集,的,實戰,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL修改字符集的實戰教程》相關的同類信息!
  • 本頁收集關于MySQL修改字符集的實戰教程的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲图片欧美色图| 亚洲美女视频在线| 色域天天综合网| 蜜臀精品一区二区三区在线观看 | 亚洲精选一二三| 国产成人夜色高潮福利影视| 亚洲aaa精品| 《视频一区视频二区| 日韩精品一区二区三区中文精品 | 成人小视频免费观看| 亚洲h精品动漫在线观看| 国产欧美一区二区三区鸳鸯浴| 欧美日韩中字一区| 99久久婷婷国产| 激情综合五月婷婷| 久久亚洲私人国产精品va媚药| 欧美日韩国产免费| 99精品国产91久久久久久| 国产一区欧美日韩| 奇米影视一区二区三区| 亚洲国产日韩av| 亚洲免费视频中文字幕| 久久久不卡网国产精品一区| 日韩欧美一区二区在线视频| 欧美羞羞免费网站| 91浏览器在线视频| 亚洲一二三专区| 亚洲视频一二区| 国产精品久久久久毛片软件| 久久久99精品免费观看不卡| 欧美电视剧在线看免费| 欧美一区二区精品在线| 欧美日韩国产大片| 欧美视频一区二区三区四区| 91久久香蕉国产日韩欧美9色| 成人三级伦理片| 国产乱理伦片在线观看夜一区 | 免费成人结看片| 亚洲午夜久久久久久久久电影院| 中文字幕欧美一| 中文字幕制服丝袜一区二区三区| 国产精品久久久一区麻豆最新章节| 久久精品在线免费观看| 久久久久久久久久久99999| 精品久久久久久综合日本欧美 | 精品日韩在线观看| 日韩免费视频一区二区| 欧美成人国产一区二区| 国产成人在线网站| 福利电影一区二区三区| 国产一区二区三区四| 国产一区二区不卡老阿姨| 国产精品一区三区| 风间由美一区二区av101| 国产很黄免费观看久久| 丁香婷婷综合激情五月色| 国产福利精品一区二区| 成人黄色av网站在线| 99v久久综合狠狠综合久久| 91影视在线播放| 日本不卡视频在线| 久久精品国产亚洲5555| 国产成人午夜精品5599 | 欧美高清视频一二三区 | 日韩精品一区二区三区在线| 久久综合色之久久综合| 国产精品欧美一区喷水| 亚洲狼人国产精品| 国产亚洲午夜高清国产拍精品| 中文字幕免费不卡在线| 中文字幕欧美一| 日韩经典一区二区| 国产成人精品免费看| 色婷婷综合在线| 日韩欧美二区三区| 国产精品久久久久四虎| 午夜精品福利一区二区蜜股av| 久久国产三级精品| 成人精品国产一区二区4080| 欧美色爱综合网| www精品美女久久久tv| 综合久久综合久久| 蜜臀av一区二区在线观看| 成人在线视频一区| 欧美情侣在线播放| 久久久久久免费网| 亚洲综合色噜噜狠狠| 精品制服美女丁香| 日本韩国视频一区二区| 日韩一本二本av| 一区二区三区在线免费| 国产精品影视在线观看| 欧美性极品少妇| 日本一区二区不卡视频| 蜜桃久久久久久久| 91麻豆精品视频| 久久蜜桃一区二区| 成人avav在线| 91精品国产综合久久久久久| 中文字幕视频一区二区三区久| 久久精品国产一区二区| 色婷婷国产精品| 欧美高清一级片在线观看| 蜜臀久久久久久久| 在线这里只有精品| 国产精品久久久久三级| 国产一区二区中文字幕| 欧美久久一二三四区| 亚洲黄色性网站| 成人动漫av在线| 久久久久久毛片| 美女尤物国产一区| 乱中年女人伦av一区二区| 色婷婷av一区二区三区大白胸| 中国av一区二区三区| 九色综合狠狠综合久久| 欧美乱妇15p| 欧美一二区视频| 亚洲成av人片观看| 欧洲在线/亚洲| 亚洲视频在线观看一区| 成人动漫精品一区二区| 久久久久国产免费免费| 精品一二线国产| 欧美老女人第四色| 图片区小说区国产精品视频| 色狠狠一区二区三区香蕉| 中文字幕亚洲综合久久菠萝蜜| 亚洲视频 欧洲视频| 不卡高清视频专区| 国产蜜臀av在线一区二区三区| 狠狠网亚洲精品| 精品国产91亚洲一区二区三区婷婷| 日欧美一区二区| 精品视频1区2区| 天天av天天翘天天综合网| 欧美二区三区91| 午夜精品福利一区二区蜜股av | 午夜电影一区二区| 久久精品国产精品青草| 欧美一区午夜精品| 日本不卡一区二区三区高清视频| 欧美日韩精品三区| 亚洲成a人片在线观看中文| 欧美日韩中文字幕精品| 丝袜亚洲另类丝袜在线| 91精品国产手机| 久久99国内精品| 国产日韩欧美高清在线| 成人精品视频一区二区三区尤物| 一色屋精品亚洲香蕉网站| 色av一区二区| 三级影片在线观看欧美日韩一区二区 | www.一区二区| 亚洲欧洲中文日韩久久av乱码| 在线日韩av片| 三级精品在线观看| 精品久久久久香蕉网| 成人美女视频在线观看| 国产精品短视频| 欧美午夜理伦三级在线观看| 丝袜脚交一区二区| 2021中文字幕一区亚洲| a4yy欧美一区二区三区| 亚洲国产欧美日韩另类综合| 日韩欧美一级精品久久| 国产成人av一区二区三区在线| 亚洲免费电影在线| 欧美日韩大陆一区二区| 91免费看片在线观看| 青青草精品视频| 国产精品私人自拍| 欧美三级中文字幕在线观看| 精品影视av免费| 亚洲日本va午夜在线影院| 欧美日韩视频不卡| 粉嫩13p一区二区三区| 一区二区三区精品视频| 欧美videofree性高清杂交| 不卡欧美aaaaa| 欧美aⅴ一区二区三区视频| 欧美激情在线观看视频免费| 欧美三级电影一区| 风流少妇一区二区| 日本亚洲三级在线| 国产精品九色蝌蚪自拍| 欧美一级一区二区| 99精品黄色片免费大全| 精品亚洲国产成人av制服丝袜 | 欧美三级电影精品| 国产精品99久久久久久宅男| 亚洲国产精品久久久男人的天堂| 国产成人av影院| 免费在线观看不卡| 亚洲精品少妇30p| 久久久天堂av| 91精品一区二区三区久久久久久 | 一区二区不卡在线视频 午夜欧美不卡在 | 伊人一区二区三区| 久久免费电影网|