SqlServer中-char varchar nvarchar的区别

时间:2023-01-21 08:03:40

说说nvarchar和varchar的区别:的区别:     
varchar:  可变长度,存储ANSI字符,根据数据长度自动变化。     
nvarchar: 可变长度,存储Unicode字符,根据数据长度自动变化。     
nvarchar(n) :包含 n个字符的可变长度 Unicode 字符数据。n 的值必须介于 1  与  4,000 之间。字节的存储大小是所输入字符个数的两倍。      
varchar[(n)]:长度为 n 个字节的可变长度且非 Unicode的字符数据。n 必须是一个介于 1 和 8,000之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节

从以上可以看出nvarchar是以字符方式存储, 因为用Unicode编码,

这里大家可以看看这篇博客:
各种编码的详解:http://blog.csdn.net/lvxiangan/article/details/8151670
因此可以说是规定nvarchar是双字节存储,不管你存储的是汉字还是英文字母都是占两个字节,      
分析nvarchar优缺点:       

优点:判断字符串的时候可以不需要考虑中英文两种字符的差别,可以避免程序中乱码的问题。
缺点:存储英文字符会增大一倍的存储空间.但是在存储代价已经很低廉的情况下,优先考虑兼容性会给你带来更多好处的,效率没有varchar高。
char在此不做多解释与MySQL情况一致。  
   
一般使用情况说明:
存储的数据长度确定如电话号码,编码等固定的,而且不包中文的,可以选择char类型。   

存储的数据长度不确定,存储只有英文、数字的最好用varchar。

存储的数据长度不确定,也有可能有中文,可以选择nvarchar类型。