当前位置:  开发笔记 > 编程语言 > 正文

SQL Server中的char,nchar,varchar和nvarchar有什么区别?

如何解决《SQLServer中的char,nchar,varchar和nvarchar有什么区别?》经验,为你挑选了10个好方法。

是什么意思nvarchar

是什么区别char,nchar,varchar,和nvarchar在SQL Server?



1> Brian Kim..:

只是为了清理...或总结......

ncharnvarchar可以存储Unicode字符.

char并且无法存储Unicode字符.varchar

char并且nchar固定长度的,即使您没有用尽所有空间,也会为您指定的字符数保留存储空间.

varchar并且nvarchar可变长度的,只会占用你存储的字符的空格.它不会像char或那样保留存储空间nchar.

nchar并且nvarchar将占用两倍的存储空间,因此仅在需要Unicode支持时使用它们才是明智之举.


char和varchar并不意味着存储unicode,但是通过一些额外的编码技巧和额外的逻辑,你仍然可以滥用[var] char字段来进行unicode存储.
依赖于排序规则依赖于`n ...`版本是否占用了两倍的存储空间[我的答案显示](http://stackoverflow.com/q/8250586/73226)
保留存储有什么好处?
@BenCaine char(20)将使用20个字节(假设8位整理); varchar(20)将使用len(数据)+2个字节,即22个用于20个字节的数据,但只有12个用于10个字节的数据.额外的两个字节是长度记录.如果您的数据始终是全长,那么使用char,因为它可以节省空间并且可能更快.请不要使用varchar(1),或者确实使用小于varchar(4)的任何东西.varchar格式的单个字符使用三个字节,因此char(3)永远不会使用比varchar(3)更多的空间.
在最后一点:在大多数情况下,使用Unicode nchar和nvarchar仍然更好,更好的整理,用户的灵活性,消除了未来的兼容性问题.顺便说一下,存储空间对于这种情况来说不是问题,因为使用没有Unicode的排序是很麻烦的,并且将来内存率会继续下降

2> Martin Smith..:

到目前为止,所有答案都表明varchar是单字节,nvarchar 是双字节.第一部分实际上取决于整理,如下图所示.

DECLARE @T TABLE
(
C1 VARCHAR(20) COLLATE Chinese_Traditional_Stroke_Order_100_CS_AS_KS_WS,
C2 NVARCHAR(20)COLLATE  Chinese_Traditional_Stroke_Order_100_CS_AS_KS_WS
)

INSERT INTO @T 
    VALUES (N'???????',N'???????'),
           (N'abc',N'abc');

SELECT C1,
       C2,
       LEN(C1)        AS [LEN(C1)],
       DATALENGTH(C1) AS [DATALENGTH(C1)],
       LEN(C2)        AS [LEN(C2)],
       DATALENGTH(C2) AS [DATALENGTH(C2)]
FROM   @T  

返回

在此输入图像描述

请注意,??字符仍未在VARCHAR版本中表示,并以静默替换?.

在整理中,实际上仍然没有可以被单个字节重新编写的中文字符.唯一的单字节字符是典型的西方ASCII集.

因此,从nvarchar(X)列到varchar(X)列的插入可能会因截断错误而失败(其中X表示在两个实例中都相同的数字).

SQL Server 2012添加了支持的SC(Supplementary Character)排序规则UTF-16.在这些排序规则中,单个nvarchar字符可能需要2或4个字节.


我正在寻找的那种答案.为了节省我这样的时间 - 非英语文本转换为"中华人民共和国"https://translate.google.com/#auto/en/%E4%B8%AD%E5%8D%8E %E4%BA%BA%E6%B0%91%E5%85%B1%E5%92%8C%E5%9B%BD

3> Luke Bennett..:

与nvarchar和varchar一样,nchar和char几乎以完全相同的方式运行.它们之间的唯一区别是nchar/nvarchar存储Unicode字符(如果需要使用扩展字符集则必不可少),而varchar则不存在.

由于Unicode字符需要更多存储空间,因此nchar/nvarchar字段占用的空间是原来的两倍(例如,在早期版本的SQL Server中,nvarchar字段的最大大小为4000).

这个问题是一个重复的这一个.


你忘记了一件事:nchar使用固定长度,因此nchar(10)总是需要接收10个字符.varchar(10)确实是Unicode,可以接受任意数量的字符,最多10个字符.另请参阅http://msdn.microsoft.com/en-us/library/ms186939.aspx

4> 小智..:

只是添加更多内容: nchar - 为数据添加尾随空格. nvarchar - 不向数据添加尾随空格.

因此,如果您要通过'nchar'字段过滤数据集,则可能需要使用RTRIM来删除空格.例如,名为BRAND的nchar(10)字段存储单词NIKE.它在单词的右侧增加了6个空格.因此,在过滤时,表达式应为: RTRIM(Fields!BRAND.Value)="NIKE"

希望这有助于那里的人,因为我刚才有点挣扎!



5> PeterAllenWe..:

我试图总结并纠正现有的答案:

首先,char并且nchar将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,varchar而且nvarchar将仅使用存储该字符串所需的存储空间(加上两个字节的开销,大概是存储字符串长度).所以请记住,"var"的意思是"变量",就像在变量空间中一样.

第二个主要的角度来理解的是,ncharnvarchar使用存储字符串恰好每个字符用两个字节,而charvarchar使用由核对代码页确定的编码,这将通常是每个字符正好一个字节(尽管有例外,见下文).通过每个字符使用两个字节,一个非常广泛的字符可以存储,所以要记住的基本的事情是,ncharnvarchar往往是一个更好的选择,当你想要国际化的支持,你可能做的.

现在为一些更好的点.

首先,ncharnvarchar始终使用UCS-2存储数据.这意味着将使用每个字符恰好两个字节,并且基本多语言平面(BMP)中的任何Unicode字符都可以由ncharnvarchar字段存储.但是,不存在任何 Unicode字符的情况.例如,根据维基百科,埃及象形文字的代码点不属于BMP.因此,Unicode字符串可以用UTF-8和其他真正的Unicode编码表示,这些编码不能存储在SQL Server ncharnvarchar字段中,并且用埃及象形文字编写的字符串也将在其中.幸运的是,您的用户可能不会写入该脚本,但请注意这一点!

其他海报突出显示的另一个令人困惑但有趣的观点是,如果校对代码页需要char,varchar字段可能会为某些字符使用每个字符两个字节.(Martin Smith给出了一个很好的例子,他展示了Chinese_Traditional_Stroke_Order_100_CS_AS_KS_WS如何表现出这种行为.检查出来.)

更新:从SQL Server 2012开始,最后有UTF-16的代码页,例如Latin1_General_100_CI_AS_SC,它可以真正覆盖整个Unicode范围.



6> 小智..:

char:固定长度的字符数据,最大长度为8000个字符.

nchar:固定长度的unicode数据,最大长度为4000个字符.

Char = 8位长度

NChar = 16位长度



7> Rasel..:

nchar[(n)] (国民性)

固定长度的Unicode字符串数据.

n 定义字符串长度,并且必须是1到4,000之间的值.

存储大小是两倍n字节.


nvarchar [(n | max)] (国民性格不同.)

可变长度的Unicode字符串数据.

n 定义字符串长度,可以是1到4,000之间的值.

max 表示最大存储大小为2 ^ 31-1个字节(2 GB).

存储大小(以字节为单位)是输入数据的实际长度的两倍+ 2个字节


char [(n)] (字符)

固定长度的non-Unicode字符串数据.

n 定义字符串长度,并且必须是1到8,000之间的值.

存储大小是n字节.


varchar [(n | max)] (性格变化)

可变长度的非Unicode字符串数据.

n 定义字符串长度,可以是1到8,000之间的值.

max 表示最大存储大小为2 ^ 31-1个字节(2 GB).

存储大小是输入数据的实际长度+ 2个字节.



8> 小智..:

nchar需要 nvarchar 更多的空间.

例如,

即使您只输入5,char(100)也将始终存储100个字符,其余95个字符将填充空格.在varchar(100)中存储5个字符将保存5个字符.


不完全正确,因为您需要填充最多100个字符的char(100).当您在数据库中存储电话号码或订购具有固定长度的号码时,您可以使用此功能.由于字段长度是固定的,因此您无法将其填充到最大字符数.但是当所有数据都是每个记录100个字符时,char(100)将比varchar(100)占用更少的存储空间,因为它不需要长度指示:每个值都只有100个字符.

9> Wim ten Brin..:

不同之处是:

    n [var] char存储unicode,而[var] char只存储单字节字符.

    [n] char需要具有确切长度的固定数量的字符,而[n] varchar接受可变数量的字符,直到并包括定义的长度.

另一个区别是长度.nchar和nvarchar都可以长达4,000个字符.char和varchar最长可达8000个字符.但是对于SQL Server,您还可以使用[n] varchar(max),它最多可以处理2,147,483,648个字符.(两千兆字节,一个带符号的4字节整数.)



10> Jason Kresow..:

nchar(10)是一个长度为10的固定长度的Unicode字符串.nvarchar(10)是一个可变长度的Unicode字符串,最大长度为10.通常,如果所有数据值都是10个字符,则使用前者如果长度变化.

推荐阅读
N个小灰流_701
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有