他们的存储方式和数据的检索方式都不同。sql
数据的检索效率是:char>varchar>text服务器
空间占用方面,要具体状况具体分析了。函数
CHAR(M) | M个字节,0 <=M<= 255 |
VARCHAR(M) | L+1个字节,其中L<=M且0 <=M<= 65535 |
TEXT | L+2个字节,其中L< 216 |
Char为定长,varchar,text为变长测试
Char在保存的时候,后面(右边)会用空格填充到指定的长度,在检索的时候后面的空格会去掉,因此检索出来的数据须要再用什么trim之类的函数去处理。(与sql server可能有些不一样)spa
Varchar在保存的时候,不进行填充。当值保存和检索时尾部的空格仍保留。server
TEXT列不能有默认值,存储或检索过程当中,不存在大小写转换.get
当存储的字符超过他们定义的长度时候,若是不是在sql服务器的严格模式下,都会自动截取合适的字段存储,而不会出现错误。可是,若是是中文的话一样要报错误:)好比定义char(4),而后insert (‘c哈哈’).io
注意一点的,Char,Varchar不像数值类型,有系统默认长度,因此必须在括号里定义长度,能够有默认值table
text不能够写默认值,后面若是指定长度,不会报错误,可是这个长度是不起做用的,意思就是你插入数据的时候,超过你指定的长度仍是能够正常插入(严格模式下没有测试:))效率
存储计算:
在使用UTF8字符集的时候,手册上是这样描叙的:
· 基本拉丁字母、数字和标点符号使用一个字节。
· 大多数的欧洲和中东手写字母适合两个字节序列:扩展的拉丁字母(包括发音符号、长音符号、重音符号、低音符号和其它音符)、西里尔字母、希腊语、亚美尼亚语、希伯来语、阿拉伯语、叙利亚语和其它语言。
· 韩语、中文和日本象形文字使用三个字节序列。
char会形成空间浪费,可是有速度优点;而varchar节省了空间,可是速度就不如char。
常常变化的字段用varchar
知道固定长度的用char
尽可能用varchar
超过255字节的只能用varchar或者text
能用varchar的地方不用text