SQL varchar中文乱码,nvarchar正常的问题
(2017-04-24 21:47:35)分类: 数据库 |
varchar在SQL
Server中是采用单字节来存储数据的,nvarchar是使用Unicode来存储数据的.
中文字符存储到SQL
Server中会保存为两个字节(一般采用Unicode编码),英文字符保存到数据库中,如果类型为varchar,则只占一个字节,而如果类型为nvarchar,则会占两个字节.
正常情况下,我们使用varchar也可以存储中文字符,但是如果遇到英文操作系统并且对中文字体的支持不完全,
则在类型为varchar就会出现乱码(显示为??).
但如果布署的主机是英文操作系统,并且不支持中文环境,那问
题就出来了.所有的varchar字段在存储中文的时候都会变成乱码(显示为??).
使用nvarchar的另一个好处就是在判断字符串的时候可以不需要考虑中英文两种字符的差别.
尽管使用nvarchar存储英文字符会增大一倍的存储空间.但是在存储代价已经很低廉的情况下,优先考虑兼容性会给你带来更多好处的.
1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间。
2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为
VARCHAR(10)是最合算的。
3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。
4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。
所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar