首先
-
1.char:固定长度,存储英文字符,不能包含中文字符。
-
2.nchar:固定长度,是unicode来存储字符,可以包含中文字符。
-
3.varchar:可变长度,存储英文字符,不能包含中文字符。按需、按照字节存储,节约空间。
-
4.nvarchar:可变长度,采用unicode来存储,可以存储中文,相对varchar来说会比varchar大一倍的空间。
区别
1.前面加“n”与不加“n”
- char、varchar、这两个只能用于单字节来存储数据,适合英文,中文会不兼容。我们常用的汉字需要用两个字节来存储,所以就要使用nchar、nvarchar。
- char、varchar因为是单字节的所以在存储的时候最大数值可以达到8000,而nchar、nvarchar是最大数值4000。
2.char与varchar的区别
- char(10)就是给予一个固定的空间,不管存储的内容有没有到达10个字节,都占用10个字节的空间,同时,varchar(10)和nvarchar(10)的最大空间 只能为10字节,如果不到10字节就不占用10字节。
如何使用
1.如果你肯定存储的数据长度,而且不包中文的,可以选择char类型。
2.如果肯定存储的数据长度,但可能包括中文,可以选择nchar类型。
3.如果不确定存储的数据长度,存储只有英文、数字的最好用varchar类型
4.如果不确定存储的数据长度,也有可能有中文,可以选择nvarchar类型