0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MySQL字符集的設(shè)置修改和排序規(guī)則

汽車玩家 ? 來源:數(shù)據(jù)庫的那些事 ? 作者:數(shù)據(jù)庫的那些事 ? 2020-04-16 17:10 ? 次閱讀

1、字符集概述

大家都知道,計算機只能識別二進制碼,為了讓計算機能處理文字,人們給每個文字進行編碼,這個編碼就是計算機字符集的由來。

字符集是多個字符的集合,而字符是各種文字、符號和編碼的總稱。MySQL提供了字符集支持,可以使用各種字符集存儲數(shù)據(jù)??梢栽诜?wù)器,數(shù)據(jù)庫,表和列級別指定字符集。

MySQL字符集的設(shè)置修改和排序規(guī)則

MySQL常用字符集

MySQL字符集的設(shè)置修改和排序規(guī)則

MySQL排序規(guī)則后綴

2、MySQL的字符集和排序規(guī)則

字符集:用來定義MySQL存儲字符串的方式

排序規(guī)則:用來定義比較字符串的方式。

字符集和排序規(guī)則是一對多的關(guān)系。

在同一服務(wù)器,同一數(shù)據(jù)庫甚至同一表中混合使用具有不同字符集或排序規(guī)則的字符串

3、MySQL字符集的設(shè)置

服務(wù)器字符集和排序規(guī)則

服務(wù)器字符集和排序規(guī)則,可以在MySQL的配置文件匯中設(shè)置。

在my.cnf中設(shè)置

[mysql]
character_set_server=utf8

查詢當前服務(wù)器的字符集和排序規(guī)則

show variables like 'character_set_server';
show variables like 'collation_server';

數(shù)據(jù)庫字符集和排序規(guī)則

數(shù)據(jù)庫字符集和排序規(guī)則可以在創(chuàng)建數(shù)據(jù)庫的時候指定,也可以在創(chuàng)建完數(shù)據(jù)庫后通過‘a(chǎn)lter database’命令進行修改。如果數(shù)據(jù)庫里已經(jīng)存在數(shù)據(jù),則以前的數(shù)據(jù)還是按照久的字符集進行存儲,新數(shù)據(jù)按照新的字符集存放。

設(shè)置數(shù)據(jù)庫字符集和排序規(guī)則

MySQL字符集的設(shè)置修改和排序規(guī)則

設(shè)置數(shù)據(jù)庫字符集和排序規(guī)則

查詢當前數(shù)據(jù)庫的字符集和排序規(guī)則

show variables like 'character_set_database';
show variables like 'collation_ database';

MySQL設(shè)置數(shù)據(jù)庫字符集和排序規(guī)則的規(guī)則如下:

如果指定了字符集和排序規(guī)則,則使用指定的字符集和排序規(guī)則

如果指定了字符集未指定排序規(guī)則,則使用指定字符集其默認排序規(guī)則

如果指定了排序規(guī)則但未指定字符集,則使用與排序規(guī)則相關(guān)的字符集

如果未指定字符集和排序規(guī)則,則使用服務(wù)器字符集和服務(wù)器排序規(guī)則。

表字符集和排序規(guī)則

表的字符集和排序規(guī)則在創(chuàng)建表的時候指定,也可以通過alter table命令進行修改,如果表中已有數(shù)據(jù),修改字符集對原有數(shù)據(jù)沒有影響。

設(shè)置表字符集和排序規(guī)則

MySQL字符集的設(shè)置修改和排序規(guī)則

設(shè)置表字符集和排序規(guī)則

查詢當前表的字符集和排序規(guī)則

show create table

MySQL設(shè)置表字符集和排序規(guī)則的規(guī)則如下:

如果指定了字符集和排序規(guī)則,則使用指定的字符集和排序規(guī)則

如果指定了字符集未指定排序規(guī)則,則使用指定字符集其默認排序規(guī)則

如果指定了排序規(guī)則但未指定字符集,則使用與排序規(guī)則相關(guān)的字符集

如果未指定字符集和排序規(guī)則,則使用數(shù)據(jù)庫字符集和服務(wù)器排序規(guī)則。

列字符集和排序規(guī)則

每個“ 字符 ”列(即,類型列 CHAR, VARCHAR中, TEXT類型)都有字符集和列排序規(guī)則。列定義語法,CREATE TABLE并 ALTER TABLE具有用于指定列字符集和排序規(guī)則的可選子句:

MySQL字符集的設(shè)置修改和排序規(guī)則

設(shè)置列字符集和排序規(guī)則

查詢當前列的字符集和排序規(guī)則

show create table

MySQL設(shè)置列字符集和排序規(guī)則的規(guī)則如下:

如果指定了字符集和排序規(guī)則,則使用指定的字符集和排序規(guī)則

如果指定了字符集未指定排序規(guī)則,則使用指定字符集其默認排序規(guī)則

如果指定了排序規(guī)則但未指定字符集,則使用與排序規(guī)則相關(guān)的字符集

如果未指定字符集和排序規(guī)則,則使用表字符集和服務(wù)器排序規(guī)則。

4、MySQL字符集修改

修改帶有歷史數(shù)據(jù)的數(shù)據(jù)庫的字符集,步驟如下:

導(dǎo)出表結(jié)構(gòu)

手工修改導(dǎo)出文件的字符集為新的字符集

導(dǎo)出所有記錄

修改數(shù)據(jù)文件的字符集

創(chuàng)建新的數(shù)據(jù)庫

利用導(dǎo)出的文件建表

利用導(dǎo)出的文件導(dǎo)入數(shù)據(jù)

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)庫
    +關(guān)注

    關(guān)注

    7

    文章

    3807

    瀏覽量

    64427
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    813

    瀏覽量

    26599
收藏 人收藏

    評論

    相關(guān)推薦

    云服務(wù)器 Flexus X 實例 MySQL 應(yīng)用加速測試

    文章目錄 目錄 文章目錄 ? 購買配置 ? 基本配置參考如下: ? 連接服務(wù)器 ? 查詢MySQL狀態(tài) ? 啟動MySQL ? 添加配置 ? 添加密碼并修改權(quán)限 ? 性能測試 ? C#插入數(shù)據(jù)測試
    的頭像 發(fā)表于 12-24 12:19 ?154次閱讀
    云服務(wù)器 Flexus X 實例 <b class='flag-5'>MySQL</b> 應(yīng)用加速測試

    Linux系統(tǒng)設(shè)置用戶密碼規(guī)則(復(fù)雜密碼策略)方法

    Linux系統(tǒng)下的用戶密碼的有效期 可以修改密碼可以通過login.defs文件控制。設(shè)置密碼過期期限(默認情況下,用戶的密碼永不過期。) 編輯 /etc/login.defs 文件,可以設(shè)置當前
    的頭像 發(fā)表于 12-07 09:24 ?289次閱讀

    4G模組LuatOS開發(fā)|iconv字符集轉(zhuǎn)換技術(shù)篇

    本次我要講的是4G模組LuatOS開發(fā)的iconv字符集轉(zhuǎn)換,已整理成文,今天便分享供大家。
    的頭像 發(fā)表于 11-30 09:53 ?211次閱讀
    4G模組LuatOS開發(fā)|iconv<b class='flag-5'>字符集</b>轉(zhuǎn)換技術(shù)篇

    香港云服務(wù)器怎么部署MySQL數(shù)據(jù)庫?

    服務(wù)器 執(zhí)行以下命令安裝 MySQL 服務(wù)器: sudo apt install mysql-server 在安裝過程中,系統(tǒng)將提示你設(shè)置 MySQL 的 root 用戶密碼,請記住
    的頭像 發(fā)表于 11-14 16:15 ?181次閱讀

    網(wǎng)關(guān)的設(shè)置規(guī)則

    網(wǎng)關(guān)的設(shè)置規(guī)則涉及多個方面,包括硬件安裝、網(wǎng)絡(luò)連接、基本配置、高級配置以及安全設(shè)置等。以下是一篇關(guān)于網(wǎng)關(guān)設(shè)置規(guī)則的詳細指南,旨在幫助用戶正確
    的頭像 發(fā)表于 09-30 11:48 ?2022次閱讀

    AD9元器件間距規(guī)則如何設(shè)置

    在Altium Designer 9(簡稱AD9)中設(shè)置元器件間距規(guī)則,主要是為了確保PCB(Printed Circuit Board,印刷電路板)上的元器件之間保持適當?shù)木嚯x,以避免短路、干擾或
    的頭像 發(fā)表于 09-02 15:26 ?3846次閱讀

    Jtti:MySQL初始化操作如何設(shè)置root密碼

    MySQL初始化時,可以通過以下步驟設(shè)置root密碼: 打開命令行工具,使用以下命令啟動MySQL服務(wù): ? sudo service mysql start ? 使用以下命令登錄
    的頭像 發(fā)表于 08-08 16:45 ?375次閱讀

    華納云:如何修改MySQL的默認端口

    更改MySQL的默認端口。 理解MySQL配置文件 MySQL的配置文件是控制服務(wù)器設(shè)置的關(guān)鍵。在不同的操作系統(tǒng)中,這個文件可能位于不同的位置: Linux: /etc/
    的頭像 發(fā)表于 07-22 14:56 ?318次閱讀
    華納云:如何<b class='flag-5'>修改</b><b class='flag-5'>MySQL</b>的默認端口

    MySQL的整體邏輯架構(gòu)

    支持多種存儲引擎是眾所周知的MySQL特性,也是MySQL架構(gòu)的關(guān)鍵優(yōu)勢之一。如果能夠理解MySQL Server與存儲引擎之間是怎樣通過API交互的,將大大有利于理解MySQL的核心
    的頭像 發(fā)表于 04-30 11:14 ?455次閱讀
    <b class='flag-5'>MySQL</b>的整體邏輯架構(gòu)

    MySQL忘記root密碼解決方案

    mysql登錄密碼為password()算法加密,解密成本太高,以下為通用方案; 原理:mysql提供了特殊啟動方式,即跳過權(quán)限表驗證,啟動后,登錄不需要提供密碼; 登錄后,即可修改
    的頭像 發(fā)表于 04-23 16:08 ?716次閱讀

    UCGUI edit輸入框內(nèi)字符串如何單獨用光標選中某字符進行修改?

    如題: UCGUI edit輸入框內(nèi)字符串如何單獨用光標選中某字符進行修改? 使用場景: 對RTC芯片進行校時。GUI繪畫虛擬鍵盤:edit輸入框、虛擬按鍵;用于實現(xiàn)年月子時分秒時間的輸入。 現(xiàn)在
    發(fā)表于 04-23 06:14

    Altium Designer電氣規(guī)則設(shè)置后無報錯原因解析

    可是很多時候我們明明是在規(guī)則編輯器里面設(shè)置規(guī)則的,為什么在我們規(guī)則之外的時候它竟然不報錯呢?是哪里設(shè)置不對嗎?
    發(fā)表于 03-28 09:35 ?2031次閱讀
    Altium Designer電氣<b class='flag-5'>規(guī)則</b><b class='flag-5'>設(shè)置</b>后無報錯原因解析

    用FPGA實現(xiàn)雙調(diào)排序的方法(2)

    典型的排序算法包括冒泡排序、選擇排序、插入排序、歸并排序、快速排序、希爾
    的頭像 發(fā)表于 03-21 10:28 ?647次閱讀
    用FPGA實現(xiàn)雙調(diào)<b class='flag-5'>排序</b>的方法(2)

    labview 創(chuàng)建mysql 表時 設(shè)置時間 怎么在mysql中是格式是date 而不是datetime?

    選擇 時間日期 但是在mysql中是date而不是datetime類型 ,除了sql語句創(chuàng)建表 ,怎么能實現(xiàn)創(chuàng)建表中數(shù)據(jù)為datetime類型
    發(fā)表于 02-04 09:46

    pcb走線的規(guī)則設(shè)置方法介紹

    隨著電子產(chǎn)品的迅速發(fā)展,PCB(Printed Circuit Board)在電子設(shè)計中扮演著重要的角色。設(shè)計PCB走線時,合理設(shè)置規(guī)則是確保電路在安全、穩(wěn)定、高效工作的基礎(chǔ)。本文將詳細介紹PCB走
    的頭像 發(fā)表于 01-09 10:45 ?2619次閱讀