SQL字段设计之char与varchar
mysql字段的char和varchar设计区别
sqllearn.png
1,设计背景
在进行交易日志表设计卡号,姓名,身份证,手机号时,在想为什么有的时候是字段类型为char,有的时候是varchar,而且设计的长度也是不一致的。若是一般记录不多的表,影响会不大,但是当数据库的记录到千万级别的话,就可能影响到存取速度等,所有有必要进行了解。
2,char的理解
char顾名思义字符类型,占用一个字节,而且是长度是不可变的。什么意思呢,就是说当把字段定为char(10)时,而此时内容"coder"只有5个字节的长度,则剩下的5个长度为空且占着,相当于分配了10个空间存储,而当取数据的时候会进行trim(),去空格的操作。因为空间固定所以进行存取的速度更快,不过空间可能会浪费,相当于是用空间来换时间。
char对于英文字母和数字存储是每个占一个字节
3,varchar的理解
-
varchar是可变的字符类型 ,会根据内容的长度进行匹配,如定义为
varchar(10),内容为"coder"的话,就分配的长度就是5,而10是为最大值,不会浪费空间,但是存取和操作的速度慢,用时间换空间,varchar对于每个英文字符和汉字都是占用2个字节,VARCHAR数据类型时,会多用1个字节用来存储长度信息。这个管理上的开销CHAR 字符类型是没有的。 -
为了考虑冗余,可以留10%左右的字符长度。千万不能认为其为根据实际 长度来分配存储空间,因为对于内存来 说其时使用固定大小的内存块来保存值
4,Oracle中varchar2型与varchar型
1、varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;
2、varchar2把空串等同于null处理,而varchar仍按照空串处理;
3、varchar2字符要用几个字节存储,要看数据库使用的字符集,
大部分情况下建议使用varchar2类型,可以保证更好的兼容性。
5,使用场景
-
char使用:适用于固定长度的字段,如性别、身份证号、手机号等。在实际项目中, 如果某个字段的字符长度比较短此时一般是采用固定字符长度。
-
varchar适用于非固定长度的字段,如返回码、城市名等。
6,其他知识
-
nvarchar中带“n”可以理解为兼容unicode 编码和非unicode 编码,故而更适用兼容不同类型的字符。本人在项目中一直都是首选nvachar类型。若不带“n”,则意味着只能存放unicode编码的字符。
-
在Unicode中:无论英文还是日文中文都是占两个编码位置(双字节),现在的操作系统用的都是Unicode编码,所以这时中文就不用进行转换为单字节进行运行了,效率就提高了(Unicode几乎支持所有的语言编码)。区别于ASCII编码:英文字符占一个编码位置(单字节),而中文占两个位置(双字节)。