nvarchar
是什么意思?
SQL Server中char
,nchar
,varchar
和nvarchar
之间有什么区别?
答案 0 :(得分:792)
只是为了清理......或总结......
nchar
和 nvarchar
可以存储 Unicode 字符。char
且 varchar
无法存储Unicode 字符。char
和 nchar
固定长度,保留存储空间对于您指定的字符数,即使您没有用完所有空格。varchar
和 nvarchar
可变长度,只会占用您存储的字符的空格。 不会保留char
或nchar
等存储空间。 nchar
和nvarchar
将占用两倍的存储空间,因此仅在您需要 Unicode 支持时才使用它们。
答案 1 :(得分:88)
到目前为止,所有答案都表明varchar
是单字节,nvarchar
是双字节。实际上depends on collation的第一部分如下图所示。
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)
列to fail with a truncation error的插入是可能的(其中X表示两个实例中相同的数字)。
SQL Server 2012添加了支持UTF-16
的SC(补充字符)归类。在这些排序规则中,单个nvarchar
字符可能需要2或4个字节。
答案 2 :(得分:33)
nchar和char几乎以彼此完全相同的方式运行,nvarchar和varchar也是如此。它们之间的唯一区别是nchar / nvarchar存储Unicode字符(如果需要使用扩展字符集则必不可少),而varchar则不存在。
由于Unicode字符需要更多存储空间,因此nchar / nvarchar字段占用的空间是原来的两倍(例如,在早期版本的SQL Server中,nvarchar字段的最大大小为4000)。
此问题与this one重复。
答案 3 :(得分:32)
只是添加更多内容: nchar - 为数据添加尾随空格。 nvarchar - 不会向数据添加尾随空格。
因此,如果您要通过'nchar'字段过滤数据集,则可能需要使用RTRIM来删除空格。 例如。 名为BRAND的nchar(10)字段存储NIKE字样。 它在单词的右侧增加了6个空格。 因此,在过滤时,表达式应为: RTRIM(Fields!BRAND.Value)=“NIKE”
希望这可以帮助那里的人,因为我刚才有点挣扎!
答案 4 :(得分:22)
我尝试总结并纠正现有答案:
首先,char
和nchar
将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,而varchar
和{{1将只使用存储该字符串所需的存储空间(加上两个字节的开销,可能是为了存储字符串长度)。所以请记住,“var”的意思是“变量”,就像在变量空间中一样。
要理解的第二个要点是,nvarchar
和nchar
每个字符使用完全两个字节存储字符串,而nvarchar
和{{1}使用由排序规则代码页确定的编码,通常每个字符只有一个字节(虽然有例外,见下文)。通过每个字符使用两个字节,可以存储非常广泛的字符,因此在此需要记住的基本事项是char
和varchar
在您需要国际化支持时往往是更好的选择,你可能会这样做。
现在有一些更好的点。
首先,nchar
和nvarchar
列始终使用UCS-2存储数据。这意味着将使用每个字符恰好两个字节,并且基本多语言平面(BMP)中的任何Unicode字符都可以由nchar
或nvarchar
字段存储。但是,并非存在任何 Unicode字符的情况。例如,根据维基百科,埃及象形文字的代码点不属于BMP。因此,Unicode字符串可以用UTF-8和其他真正的Unicode编码表示,这些编码无法存储在SQL Server nchar
或nvarchar
字段中,并且用埃及象形文字编写的字符串将是他们。幸运的是,您的用户可能不会写入该脚本,但请注意这一点!
其他海报突出显示的另一个令人困惑但有趣的观点是,如果排序规则代码页需要,nchar
和nvarchar
字段可能会为某些字符使用每个字符两个字节。 (Martin Smith给出了一个很好的例子,他展示了Chinese_Traditional_Stroke_Order_100_CS_AS_KS_WS如何表现出这种行为。检查一下。)
UPDATE:从SQL Server 2012开始,最后有code pages for UTF-16,例如Latin1_General_100_CI_AS_SC,它可以真正覆盖整个Unicode范围。
答案 5 :(得分:14)
char
:固定长度的字符数据,最大长度为8000个字符。nchar
:固定长度的unicode数据,最大长度为4000个字符。Char
= 8位长度NChar
= 16位长度答案 6 :(得分:9)
nchar[(n)]
(国家字符)
n
定义字符串长度,且必须是1到4,000之间的值。n
字节的两倍。 nvarchar [(n | max)]
(国家字符各不相同。)
n
定义字符串长度,可以是1到4,000之间的值。max
表示最大存储大小为2 ^ 31-1个字节(2 GB)。 char [(n)]
(字符)
non-Unicode
字符串数据。n
定义字符串长度,且必须是1到8,000之间的值。n
字节。 varchar [(n | max)]
(字符不同)
n
定义字符串长度,可以是1到8,000之间的值。max
表示最大存储大小为2 ^ 31-1个字节(2 GB)。答案 7 :(得分:7)
nchar需要比 nvarchar更多的空间。
<强>例如强>
即使您只输入5,char(100)也将始终存储100个字符 剩下的95个字符将用空格填充。 在varchar(100)中存储5个字符将节省5个字符。
答案 8 :(得分:7)
另一个区别是长度。 nchar和nvarchar都可以长达4,000个字符。 char和varchar最长可达8000个字符。但是对于SQL Server,您还可以使用[n] varchar(max),它最多可以处理2,147,483,648个字符。 (两千兆字节,一个带符号的4字节整数。)
答案 9 :(得分:5)
nchar(10)是一个长度为10的固定长度的Unicode字符串.nvarchar(10)是一个可变长度的Unicode字符串,最大长度为10.通常,如果所有数据值都是10个字符,则使用前者如果长度不同,则为后者。
答案 10 :(得分:4)
nchar是固定长度的,可以保存unicode字符。它每个字符使用两个字节存储。
varchar长度可变,无法保存unicode字符。它每个字符使用一个字节存储。
答案 11 :(得分:1)
NVARCHAR 可以存储Unicode字符,每个字符占用2个字节。