什么意思 nvarchar?

之间的区别是什么 char, nchar, varchar, , nvarchar 在SQL服务器?

有帮助吗?

解决方案

只是为了清楚了...或总结一下...

  • ncharnvarchar 可以储存 Unicode 字符。
  • charvarchar 不能储存Unicode 字符。
  • charnchar固定长度 这将 储备储存空间 对于数字指定甚至如果你不使用了所有的空间。
  • varcharnvarchar变长 这只会使用空间符你的商店。它的 不会留存储喜欢 charnchar.

ncharnvarchar 将会采取了两倍多的储存空间,所以它可能是明智使用它们,如果你只需要 Unicode 支持。

其他提示

到目前为止,所有答案都表明 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  

返回

请注意,&#21326; &#22269; 字符仍未在 VARCHAR 版本中表示,并以静默替换为<代码>

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

因此,可以从 nvarchar(X)列插入 varchar(X)失败并发生截断错误(其中X表示两个实例中相同的数字。)

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

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

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

此问题与此问题重复。

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

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

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

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

首先, char nchar 将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,而 varchar nvarchar 将仅使用存储该字符串所需的存储空间(加上两个字节的开销,可能用于存储字符串长度)。所以请记住,“var”表示“变量”,如在变量空间中。

要理解的第二个要点是, 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如何表现出这种行为。检查一下。)

更新:从SQL Server 2012开始,终于有了代码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的字节(2GB)。
  • 储存的大小、字节,是两次实际的长度的数据输入+2个字节

char [(n)] (文字)

  • 固定长度, non-Unicode 串数据。
  • n 定义串的长度并且必须是一个值从1到8 000人。
  • 储存的大小 n 字节。

varchar [(n | max)] (性格不同)

  • 变长, 非Unicode 串数据。
  • n 定义串的长度,可以是一个值从1到8 000人。
  • max 表示最大储存的尺寸是2^31-1的字节(2GB)。
  • 储存的大小是实际的长度的数据输入+2节。

差异是:

  1. n [var] char存储unicode,而[var] char只存储单字节字符。
  2. [n] char需要精确长度的固定数量的字符,而[n] varchar接受可变数量的字符,包括定义的长度。
  3. 另一个区别是长度。 nchar和nvarchar都可以长达4,000个字符。 char和varchar最长可达8000个字符。但是对于SQL Server,您还可以使用[n] varchar(max),它最多可以处理2,147,483,648个字符。 (两千兆字节,一个带符号的4字节整数。)

nchar需要 nvarchar更多的空间。

<强>例如

即使您只输入5,char(100)也将始终存储100个字符 剩下的95个字符将用空格填充。 在varchar(100)中存储5个字符将节省5个字符。

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

  • 仅必固定长和可持unicode符。它使用两个字节储存每个字符。

  • varchar是可变的长度和无法持有unicode符。它使用一个字存储每个字符。

NVARCHAR 可以存储Unicode字符,每个字符占用2个字节。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top