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

nvarchar是什么意思?

SQL Server中的charncharvarcharnvarchar什么区别?


#1楼

  • char :固定长度的字符数据,最大长度为8000个字符。
  • nchar :固定长度的unicode数据,最大长度为4000个字符。
  • Char = 8位长度
  • NChar = 16位长度

#2楼

不同之处是:

  1. n [var] char存储unicode,而[var] char只存储单字节字符。
  2. [n] char需要具有确切长度的固定数量的字符,而[n] varchar接受可变数量的字符,直到并包括定义的长度。

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


#3楼

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

首先, charnchar将始终使用固定数量的存储空间,即使要存储的字符串小于可用空间,而varcharnvarchar将仅使用存储该字符串所需的存储空间(加上两个)开销的字节数,大概是为了存储字符串长度)。 所以请记住,“var”的意思是“变量”,就像在变量空间中一样。

第二个主要的角度来理解的是, ncharnvarchar每个字符使用正好两个字节存储字符串,而charvarchar使用由核对代码页,这通常将是每个字符正好一个字节确定的编码(虽然也有例外,见下文)。 通过对每个字符使用两个字节,可以存储非常广泛的字符,因此这里需要记住的基本事项是,当您需要国际化支持时, ncharnvarchar往往是更好的选择。

现在为一些更好的点。

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

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

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


#4楼

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

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

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


#5楼

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


#6楼

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


#7楼

  • nchar是固定长度的,可以保存unicode字符。 它每个字符使用两个字节存储空间。

  • varchar长度可变,无法保存unicode字符。 它每个字符使用一个字节存储空间。


#8楼

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

  • ncharnvarchar可以存储Unicode字符。
  • charvarchar 无法存储Unicode字符。
  • charnchar固定长度的 ,即使您没有用尽所有空间,也会为指定的字符数保留存储空间。
  • varcharnvarchar可变长度的 ,只会占用你存储的字符的空格。 它不会保留像charnchar这样的存储空间

ncharnvarchar将占用两倍的存储空间,因此仅在需要Unicode支持时才使用它们。


#9楼

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个字节。

#10楼

nchar需要 nvarchar 更多的空间

例如,

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


#11楼

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

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

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


#12楼

到目前为止,所有答案都表明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添加了支持UTF-16 SC(Supplementary Character)排序规则。 在这些排序规则中,单个nvarchar字符可能需要2或4个字节。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值