是什么意思 nvarchar ?
nvarchar
SQL Server中 char , nchar , varchar 和 nvarchar 有什么区别?
char
nchar
varchar
只是为了清理...或总结......
nchar 和 nvarchar 可以存储 Unicode 个字符 .
char 和 varchar cannot store Unicode 个字符 .
char 和 nchar 是 fixed-length ,即使您没有用完所有空间,也会为您指定的字符数 reserve storage space .
varchar 和 nvarchar 是 variable-length ,它们只会占用您存储的字符的空格 . 它 will not reserve storage like char or nchar .
nchar 和 nvarchar 将占用两倍的存储空间,因此仅在需要Unicode支持时使用它们才是明智之举 .
到目前为止,所有答案都表明 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 版本中表示,并以 ? 静默替换 .
华
国
VARCHAR
?
在整理中,实际上仍然没有可以被单个字节重新编写的中文字符 . 唯一的单字节字符是典型的西方ASCII集 .
因此,从 nvarchar(X) 列到 varchar(X) 列的插入可能是 varchar(X) (其中X表示在两个实例中都相同的数字) .
nvarchar(X)
varchar(X)
SQL Server 2012添加了支持 UTF-16 的SC(补充字符)排序规则 . 在这些排序规则中,单个 nvarchar 字符可能需要2或4个字节 .
UTF-16
与nvarchar和varchar一样,nchar和char几乎以完全相同的方式运行 . 它们之间的唯一区别是nchar / nvarchar存储Unicode字符(如果需要使用扩展字符集则必不可少),而varchar则不存在 .
由于Unicode字符需要更多存储空间,因此nchar / nvarchar字段占用的空间是原来的两倍(例如,在早期版本的SQL Server中,nvarchar字段的最大大小为4000) .
这个问题与this one重复 .
只是添加更多内容: nchar - 为数据添加尾随空格 . nvarchar - 不向数据添加尾随空格 .
因此,如果您要通过'nchar'字段过滤数据集,则可能需要使用RTRIM来删除空格 . 例如 . 名为BRAND的nchar(10)字段存储NIKE字样 . 它在单词的右侧增加了6个空格 . 因此,在过滤时,表达式应为: RTRIM(Fields!BRAND.Value) = "NIKE"
希望这有助于那里的人,因为我刚才有点挣扎!
我试图总结并纠正现有的答案:
首先, char 和 nchar 将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,而 varchar 和 nvarchar 将仅使用存储该字符串所需的存储空间(加上两个)开销的字节数,大概是为了存储字符串长度) . 所以请记住,"var"表示"variable",就像在变量空间中一样 .
要理解的第二个要点是, nchar 和 nvarchar 存储字符串,每个字符使用两个字节,而 char 和 varchar 使用由校对代码页确定的编码,每个字符通常只有一个字节(尽管有例外,见下文) . 通过每个字符使用两个字节,可以存储非常广泛的字符,因此这里要记住的基本事项是,当您需要国际化支持时, nchar 和 nvarchar 往往是更好的选择 .
现在为一些更好的点 .
首先, nchar 和 nvarchar 列始终使用UCS-2存储数据 . 这意味着将使用每个字符恰好两个字节,并且基本多语言平面(BMP)中的任何Unicode字符都可以由 nchar 或 nvarchar 字段存储 . 但是,不存在任何Unicode字符的情况 . 例如,根据维基百科,埃及象形文字的代码点不属于BMP . 因此,Unicode字符串可以用UTF-8和其他真正的Unicode编码表示,这些编码不能存储在SQL Server nchar 或 nvarchar 字段中,并且用埃及象形文字编写的字符串也将在其中 . 幸运的是,您的用户可能不喜欢这样的东西要牢记!
其他海报突出显示的另一个令人困惑但有趣的观点是,如果整理代码页需要, char 和 varchar 字段可能会为某些字符使用每个字符两个字节 . (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范围 .
char :固定长度的字符数据,最大长度为8000个字符 .
nchar :固定长度的unicode数据,最大长度为4000个字符 .
Char = 8位长度
Char
NChar = 16位长度
NChar
nchar[(n)] (国家级人物)
固定长度 Unicode 字符串数据 .
n 定义字符串长度,并且必须是1到4,000之间的值 .
n
存储大小是 n 字节的两倍 .
nvarchar [(n | max)] (国民性格不同 . )
可变长度 Unicode 字符串数据 .
n 定义字符串长度,可以是1到4,000之间的值 .
max 表示最大存储大小为2 ^ 31-1个字节(2 GB) .
max
存储大小(以字节为单位)是输入2字节的实际数据长度的两倍
char [(n)] (字符)
固定长度, non-Unicode 字符串数据 .
non-Unicode
n 定义字符串长度,并且必须是1到8,000之间的值 .
存储大小为 n 个字节 .
varchar [(n | max)] (字符变化)
可变长度, non-Unicode 字符串数据 .
n 定义字符串长度,可以是1到8,000之间的值 .
存储大小是输入2个字节的数据的实际长度 .
The differences是:
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字节整数 . )
nchar需要 more space than nvarchar .
eg,
即使您只输入5,char(100)也将始终存储100个字符,其余95个字符将填充空格 . 在varchar(100)中存储5个字符将保存5个字符 .
nchar(10)是一个长度为10的固定长度的Unicode字符串.nvarchar(10)是一个可变长度的Unicode字符串,最大长度为10.通常,如果所有数据值都是10个字符,则使用前者如果长度变化 .
nchar是固定长度的,可以保存unicode字符 . 它每个字符使用两个字节存储空间 .
varchar的长度可变,无法保存unicode字符 . 它每个字符使用一个字节存储空间 .
NVARCHAR 可以存储Unicode字符,每个字符占用2个字节 .
12 回答
只是为了清理...或总结......
nchar 和 nvarchar 可以存储 Unicode 个字符 .
char 和 varchar cannot store Unicode 个字符 .
char 和 nchar 是 fixed-length ,即使您没有用完所有空间,也会为您指定的字符数 reserve storage space .
varchar 和 nvarchar 是 variable-length ,它们只会占用您存储的字符的空格 . 它 will not reserve storage like char or nchar .
nchar
和nvarchar
将占用两倍的存储空间,因此仅在需要Unicode支持时使用它们才是明智之举 .到目前为止,所有答案都表明
varchar
是单字节,nvarchar
是双字节 . 实际的第一部分depends on collation如下图所示 .返回
请注意,
华
和国
字符仍未在VARCHAR
版本中表示,并以?
静默替换 .在整理中,实际上仍然没有可以被单个字节重新编写的中文字符 . 唯一的单字节字符是典型的西方ASCII集 .
因此,从
nvarchar(X)
列到varchar(X)
列的插入可能是varchar(X)
(其中X表示在两个实例中都相同的数字) .SQL Server 2012添加了支持
UTF-16
的SC(补充字符)排序规则 . 在这些排序规则中,单个nvarchar
字符可能需要2或4个字节 .与nvarchar和varchar一样,nchar和char几乎以完全相同的方式运行 . 它们之间的唯一区别是nchar / nvarchar存储Unicode字符(如果需要使用扩展字符集则必不可少),而varchar则不存在 .
由于Unicode字符需要更多存储空间,因此nchar / nvarchar字段占用的空间是原来的两倍(例如,在早期版本的SQL Server中,nvarchar字段的最大大小为4000) .
这个问题与this one重复 .
只是添加更多内容: nchar - 为数据添加尾随空格 . nvarchar - 不向数据添加尾随空格 .
因此,如果您要通过'nchar'字段过滤数据集,则可能需要使用RTRIM来删除空格 . 例如 . 名为BRAND的nchar(10)字段存储NIKE字样 . 它在单词的右侧增加了6个空格 . 因此,在过滤时,表达式应为: RTRIM(Fields!BRAND.Value) = "NIKE"
希望这有助于那里的人,因为我刚才有点挣扎!
我试图总结并纠正现有的答案:
首先,
char
和nchar
将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,而varchar
和nvarchar
将仅使用存储该字符串所需的存储空间(加上两个)开销的字节数,大概是为了存储字符串长度) . 所以请记住,"var"表示"variable",就像在变量空间中一样 .要理解的第二个要点是,
nchar
和nvarchar
存储字符串,每个字符使用两个字节,而char
和varchar
使用由校对代码页确定的编码,每个字符通常只有一个字节(尽管有例外,见下文) . 通过每个字符使用两个字节,可以存储非常广泛的字符,因此这里要记住的基本事项是,当您需要国际化支持时,nchar
和nvarchar
往往是更好的选择 .现在为一些更好的点 .
首先,
nchar
和nvarchar
列始终使用UCS-2存储数据 . 这意味着将使用每个字符恰好两个字节,并且基本多语言平面(BMP)中的任何Unicode字符都可以由nchar
或nvarchar
字段存储 . 但是,不存在任何Unicode字符的情况 . 例如,根据维基百科,埃及象形文字的代码点不属于BMP . 因此,Unicode字符串可以用UTF-8和其他真正的Unicode编码表示,这些编码不能存储在SQL Servernchar
或nvarchar
字段中,并且用埃及象形文字编写的字符串也将在其中 . 幸运的是,您的用户可能不喜欢这样的东西要牢记!其他海报突出显示的另一个令人困惑但有趣的观点是,如果整理代码页需要,
char
和varchar
字段可能会为某些字符使用每个字符两个字节 . (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范围 .
char
:固定长度的字符数据,最大长度为8000个字符 .nchar
:固定长度的unicode数据,最大长度为4000个字符 .Char
= 8位长度NChar
= 16位长度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)] (字符变化)
可变长度, non-Unicode 字符串数据 .
n
定义字符串长度,可以是1到8,000之间的值 .max
表示最大存储大小为2 ^ 31-1个字节(2 GB) .存储大小是输入2个字节的数据的实际长度 .
The differences是:
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字节整数 . )
nchar需要 more space than nvarchar .
eg,
即使您只输入5,char(100)也将始终存储100个字符,其余95个字符将填充空格 . 在varchar(100)中存储5个字符将保存5个字符 .
nchar(10)是一个长度为10的固定长度的Unicode字符串.nvarchar(10)是一个可变长度的Unicode字符串,最大长度为10.通常,如果所有数据值都是10个字符,则使用前者如果长度变化 .
nchar是固定长度的,可以保存unicode字符 . 它每个字符使用两个字节存储空间 .
varchar的长度可变,无法保存unicode字符 . 它每个字符使用一个字节存储空间 .
NVARCHAR 可以存储Unicode字符,每个字符占用2个字节 .