数据库SQL程序员

SQL字段设计之char与varchar

2017-09-15  本文已影响55人  剽悍一只鸡

mysql字段的char和varchar设计区别


sqllearn.png

1,设计背景

在进行交易日志表设计卡号,姓名,身份证,手机号时,在想为什么有的时候是字段类型为char,有的时候是varchar,而且设计的长度也是不一致的。若是一般记录不多的表,影响会不大,但是当数据库的记录到千万级别的话,就可能影响到存取速度等,所有有必要进行了解。


2,char的理解

char顾名思义字符类型,占用一个字节,而且是长度是不可变的。什么意思呢,就是说当把字段定为char(10)时,而此时内容"coder"只有5个字节的长度,则剩下的5个长度为空且占着,相当于分配了10个空间存储,而当取数据的时候会进行trim(),去空格的操作。因为空间固定所以进行存取的速度更快,不过空间可能会浪费,相当于是用空间来换时间。
char对于英文字母和数字存储是每个占一个字节


3,varchar的理解


4,Oracle中varchar2型与varchar型

1、varchar2把所有字符都占两字节处理(一般情况下),varchar只对汉字和全角等字符占两字节,数字,英文字符等都是一个字节;

2、varchar2把空串等同于null处理,而varchar仍按照空串处理;

3、varchar2字符要用几个字节存储,要看数据库使用的字符集,
大部分情况下建议使用varchar2类型,可以保证更好的兼容性。


5,使用场景


6,其他知识


7,参考博客

MySQL数据库char与varchar的区别分析及使用建议

上一篇 下一篇

猜你喜欢

热点阅读