1 Character Set与Collation
任何资讯技术在处理资料的时候,如果只是单纯的数值和运算,那就不会有太复杂的问题;如果处理的资料是文字的话,就会面临世界上各种不同语言的问题。 以资料库来说,它必须正确的储存各种不同语言的文字,也就是一个资料库中,有可能同时储存繁体和简体中文、法文等不同语言的文字。
电脑在处理文字资料大多是使用一个「编码」来表示某一个字,对MySQL资料库来说,为了要处理不同语言的文字,它使用一套编码来处理一种语言的文字,称为「字元集、character set」。 以英文字母来说,每一个字母都有一个编码,例如A=65、B=66、C=67。
MySQL可以依照你的需要为资料库设定不同的字元集:
Collation指的是在一个字元集中,所有字元的大小排序规则。 以英文字母来说,我们会依照A到Z的顺序当成大小的顺序,小写的字母也是一样的。 这样的大小顺序是依照编码的大小来决定的,MySQL把它称为「binary collation」。
可是在真实的世界中,大小顺序却不是这么单纯,有时候你会把大小写的英文字母当成是一样的,例如大写的A和小写的a。 在这种情况下,大写和小写的字母会被当成是一样的大小,然后再依照编码来决定,例如大写A的编码比小写a的编码小。 MySQL把这样的方式称为「case-insensitive collation」。
在决定大小顺序的时候,如果只有考虑字母大小写因素的话,那还不算是太复杂的。 如果再考虑各种不同语言特性的话,在决定大小顺序的时候就会变得很复杂。 以繁体中文来说,它是没有区分大小写的,而且一个中文字会包含一个以上的位元组,其它的语言也都会有类似的情况。
1.1 Character Set
MySQL资料库把各种不同字元集的编码资料纪录在系统资料库中,你可以使用下列的指令查询MySQL资料库支援的字元集资讯:
SHOW CHARACTER SET
执行上列的查询指令后可以得到下列的结果:
1.2 COLLATION
MySQL除了支援各种不同的字元集,让资料库可以储存不同语言的文字外,每一种字元集都可以依照实际需要,搭配不同的Collation设定。 你可以使用下列的指令查询MySQL支援的Collation资讯:
SHOW COLLATION
执行上列的查询指令后可以得到下列的结果:
你也可以使用类似「WHERE」子句中的条件设定,查询某一种字元集支援的Collation资讯:
你可以从Collation名称分辨出排序的准则:
2 资料库
资料库(Database)是用来保存各种资料元件的容器,在安装好MySQL资料库伺服器软体后,就可以依照自己的需求建立资料库,MySQL对于资料库的数量并没有限制:
每一个MySQL资料库伺服器软体都会使用一个储存资料的资料夹,称为「data directory」。 在这个资料夹下,每建立一个资料库,MySQL都会建立一个资料夹,称为「资料库资料夹、database directory」,一个资料库包含的档案就会放在各自的资料库资料夹中:
注:使用「SHOW VARIABLES LIKE 'datadir'」叙述,可以查询MySQL资料库伺服器使用的资料库资料夹。
因为一个资料库会是档案系统中的一个资料夹,所以你要特别留意下列的特性:
- 虽然MySQL对于资料库的数量并没有限制,可是你要注意MySQL资料库伺服器软体所安装的作业系统,它对于资料夹与档案大小的限制。
- MySQL使用资料库名称作为资料库资料夹的名称,所以你要特别注意大小写的问题。 在资料夹名称不分大小写的作业系统(例如Windows),资料库名称「MyDB」和「mydb」是一样的;可是在资料夹名称会区分大小写的作业系统(例如Linux),资料库名称「MyDB」和「mydb」就不一样了。
- 每一个资料库资料夹中都有一个特别的档案,档案名称是「db.opt」,这个档案的内容是资料库的字元集与collation设定。
注:MySQL把「DATABASE」与「SCHEMA」当成是一样的,所有你在后续使用的指令,都可以把「DATABASE」换成「SCHEMA」。
点击阅读全文
更多参考:
本文转自: MySQL入门 (六) : 字元集与资料库
相关推荐
matlab入门经典教材20122-10-字元與字串.ppt matlab入门经典教材2012—2
ASCII 字元表,描述ASCII 字元表详细信息,程序员可以方便查阅。
【《熊概,字元节》阅读附答案】 熊概 字元节.docx
Gulp基本使用教学 :memo: 因为小弟觉得这东西非常实用,所以就简单写个教学文,顺便记录一下 :memo: ,希望能帮助想学的人 :grinning_face_with_...在cmd(命令提示字元)输入 node -v 如果有跑出node.js版本号代表安
【《郭震,字元振》阅读】 郭震字元振.docx
基于Android平台的“字元码”输入法研究与实现.pdf
shell的经典资料 比较值得一看的 Table of Contents 1.前言 2.佈置練習環境 Linux/FreeBSD等 Un*x 平台 Cygwin 環境 3.Bash shell 的結構 簡單的示範程式 打開執行權 執行 script 的方法 shell 使工作自動化容易 您...
可排列出可能的字元排列 譬如,abcd 共24種排法 abcd abdc acbd acdb
I :从光标所在列的第一个非空白字元前面开始插入资料。 开始 (open) o :在光标所在列下新增一列并进入输入模式。 O: 在光标所在列上方新增一列并进入输入模式。 x: 删除光标所在字符。 ...
字元集简史 . 宽字元和C . 宽字元和WINDOWS 3. 视窗和讯息 . 自己的视窗 . WINDOWS程式设计的难点 4. 输出文字 . 绘制和更新 . GDI简介 . 卷动列 . 建立更好的滚动 5. 图形基础 . GDI的结构 . 装置...
MiniGUI是由北京飞漫软件技术有限公司创办的开源Linux图形用户界面支持系统,经过近些年的发展,MiniGUI已经发展成为比较成熟的性能优良的、功能丰富的跨操作...它支持GB2312与BIG5字元集,其他字元集也可以轻松加入。
行业资料-电子功用-字元式文字输入方法及应用其方法的电子运算装置
字元集简史 . 宽字元和C . 宽字元和WINDOWS 3. 视窗和讯息 . 自己的视窗 . WINDOWS程式设计的难点 4. 输出文字 . 绘制和更新 . GDI简介 . 卷动列 . 建立更好的滚动 5. 图形基础 . GDI的结构 . 装置...
字元集简史 . 宽字元和C . 宽字元和WINDOWS 3. 视窗和讯息 . 自己的视窗 . WINDOWS程式设计的难点 4. 输出文字 . 绘制和更新 . GDI简介 . 卷动列 . 建立更好的滚动 5. 图形基础 . GDI的结构 . 装置...
此数据为csv格式 数据表包含 zcp:文字 txt:文字uincode val:文字释义 zbh:文字笔画 zyb:文字部首+余笔 zjg:文字结构 zpy:文字拼音 zqu:文字分区 zfy:两分字元 zsp:两分双拼 zms:文字描述 ...zck:参考资料
【巢谷,字元修阅读答案及翻译】巢谷传阅读答案.docx
电子政务-借助流动无线电网的短信息业务发送基本字元构成的亚洲文字.zip
背景: 在Eclipse執行Java程式在 螢幕上顯示 "简体中文" 四個字元,程式名稱 StreamWriterDemo.java 問題: 執行Java程式在 螢幕上顯示亂碼 (圖1),預期應顯示 "简体中文" 四個字元 內容包含答案與步驟