在SQL数据库的字段数据类型里面,有很多字符型的,并且,这些字符型的,有的是可变长度的,有的是不可变即固定长度的。下面我们为大家逐一介绍,方便大家以后在设置数据类型的时候,节约高效利用数据资源。
Unicode或非Unicode
数据库中,英文字符只需要一个字节存储就足够了,但汉字和其他众多非英文字符,则需要两个字节存储。如果英文与汉字同时存在,由于占用空间数不同,容易造成混乱,导致读取出来的字符串是乱码。Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。
而前缀有n的数据类型就表示Unicode字符,比如nchar,nvarchar,这两种类型使用了Unicode字符集。
定长或变长
所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;有var前缀的,表示是实际存储空间是变长的,比如varchar,nvarchar变长字符数据则不会以空格填充,比较例外的是,text存储的也是可变长。
基于以上两点来看看字段容量,char,varchar 最多8000个英文,4000个汉字,nchar,nvarchar 可存储4000个字符,无论英文还是汉字。
下面我们看看如下的几种数据类型:
char:固定长度,存储ANSI字符,不足的补英文半角空格。
nchar:固定长度,存储Unicode字符,不足的补英文半角空格
varchar:可变长度,存储ANSI字符,根据数据长度自动变化。
nvarchar:可变长度,存储Unicode字符,根据数据长度自动变化。
nText类型,也是可变长度的,根据数据长度自动变化。
应用经验技巧
如果数据量非常大,又能100%确定长度且保存只是ansi字符,那么就使用char
能确定长度又不一定是ansi字符或者,那么用nchar;
对于超大数据,如文章内容,使用nText;
其他的通用nvarchar