SQL Server Nvarchar(最大值)

Posted

技术标签:

【中文标题】SQL Server Nvarchar(最大值)【英文标题】:SQL Server Nvarchar(max) 【发布时间】:2013-01-31 19:08:12 【问题描述】:

我有一个插入语句,其中一列的列类型为 nvarchar(max) desc。我注意到,当我查看数据库中的某些记录时,desc 列有时是空白的。由于通过我的 GUI 进行了验证,我知道这是不可能的。经过进一步测试,我发现如果该列的文本太大,它就不会插入该数据。我发现这种奇怪的 b/c 我认为它会给我一些错误或不完全插入记录,但它只是将该列留空。 nvarchar(max) 是否有限制,如果有的话,我可以使用其他数据类型来代替它。我做了一个测试,我尝试插入的字符超过 20,000 个,但最终用户输入会有所不同。

'************ **编辑******** *************** *****

感谢大家的快速回复,通过研究我发现你们是正确的,它会保存(保存)这么多信息。我发现,当使用 Microsoft Management Studio 时,如果当您的结果返回时,如果您查询的列的大小有很多字符,它就会显示为空白。为了验证这一点,我使用了 len(COLUMN_NAME) 函数并看到字符长度符合我的预期。有谁知道我可以更改 Microsoft Management Studio 中的设置以实际看到结果的方法吗?

【问题讨论】:

如果您可以展示如何从代码中插入数据以及数据的实际外观,将会有所帮助。 “空白”是什么意思:NULL,一个空字符串或其他什么?其他人提到了NVARCHAR(MAX) 的限制(请参阅documentation),但您的问题中没有足够的信息来准确理解您所看到的内容。 【参考方案1】:

NVARCHAR(MAX) 有一个限制 - 它是 2^31-1 字节 (2GB)。你可以阅读更多关于它的信息at Books Online。

【讨论】:

【参考方案2】:

检查下面的链接可能会有很大帮助。

默认大小为 4000,最大大小为 2GB:

http://social.msdn.microsoft.com/Forums/en-US/databasedesign/thread/d5e0c6e5-8e44-4ad5-9591-20dc0ac7a870/

What is the maximum number of characters that nvarchar(MAX) will hold?

【讨论】:

【参考方案3】:

请参考这个link

引用:

说真的 - VARCHAR(MAX) 最多可以存储 2 GB 的数据 - 而不仅仅是 8000 个字符.....

重点是:如果您使用 varchar(max),则需要确保始终将所有 >strings 显式转换为 varchar(max) - 就像我在本示例中所做的那样。否则,SQL Server 将 > 回退到“常规” varchar 处理,并且确实限制为 8000 个字符....

【讨论】:

【参考方案4】:

varchar(max) 保存 20,000 个字符应该没有问题,所以我认为这可能与其他问题有关。

我不确定您的 GUI 使用的是什么技术,但该线程似乎在讨论类似的问题,即您使用的提供程序不支持 varchar(max) 并且可能需要更新。

Strange problem with nvarchar(max) fields and Classic ASP

这可能不是 SQL Server 的问题,而是您用来与 SQL Server 通信的技术。

您能否指定您用于与 SQL Server 通信的技术(ASP、ASP.NET、版本?)以及您使用的 SQL Server 版本。

【讨论】:

以上是关于SQL Server Nvarchar(最大值)的主要内容,如果未能解决你的问题,请参考以下文章

Linq - 从 SQL Server 中的 nvarchar 类型列中查找最大值

sql server中的存储过程最多可以有多少参数

SQL的语句最大长度限制多少字符

在sql server数据库中将一个nvarchar类型的空值转换成decimal(18,3)类型

在 sql server 中比较 nvarchar 和 bigint

Oracle 和 SQL Server 中的 NVARCHAR 之间的区别?