sql-server – SQL Server 2008 R2 Varbinary Max Size

前端之家收集整理的这篇文章主要介绍了sql-server – SQL Server 2008 R2 Varbinary Max Size前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
sql Server 2008 R2中,我可以使用varbinary(max)插入的文件的最大大小是多少?我试图将列中的最大值更改为超过8,000字节,但它不会让我,所以我猜测最大值是8,但从 this article on MSDN开始,它表示最大存储大小为2 ^ 31- 1个字节:

varbinary [ ( n | max) ]

Variable-length binary data. n can be a value from 1 through 8,000. max indicates that the maximum storage size is 2^31-1 bytes. The storage size is the actual length of the data entered + 2 bytes. The data that is entered can be 0 bytes in length. The ANSI sql synonym for varbinary is binary varying.

那么如何在varbinary字段中存储更大的文件呢?我不打算使用FILESTREAM,因为我要保存的文件最大为200kb到1mb,我正在使用的代码

UPDATE [table]
SET file = ( SELECT * FROM OPENROWSET ( BULK 'C:\A directory\A file.ext',SINGLE BLOB)    alias) 
WHERE idRow = 1

我已经能够成功地将该代码执行到小于或等于8000字节的文件.如果我尝试使用8001字节大小的文件,它将失败.我在表上的文件字段有一个名为“file”的字段varbinary(8000),正如我所说,我无法更改为更大的值.

解决方法

我无法重现这种情况.我尝试了以下方法
USE tempdb;
GO

CREATE TABLE dbo.blob(col VARBINARY(MAX));

INSERT dbo.blob(col) SELECT NULL;

UPDATE dbo.blob 
  SET col = (SELECT BulkColumn 
    FROM OPENROWSET( BULK 'C:\Folder\File.docx',SINGLE_BLOB) alias
  );

SELECT DATALENGTH(col) FROM dbo.blob;

结果:

--------
39578

如果这个上限为8K,那么我猜以下任何一个都是真的:

>该列实际上是VARBINARY(8000).>您正在Management Studio中选择数据,并分析在那里显示的数据的长度.对于文本,结果限制为最多8192个字符,如果是这种情况,因此直接对列使用DATALENGTH()是一种更好的方法.

原文链接:https://www.f2er.com/mssql/77406.html

猜你在找的MsSQL相关文章