Die*_*mos 8 sql-server varbinary sql-server-2008 sql-server-2008-r2 varbinarymax
在SQL Server 2008 R2中,我可以使用varbinary(max)插入文件的最大大小是多少?我试图将列中的最大值更改为超过8,000字节,但它不会让我,所以我猜测最大值是8,000字节,但是从MSDN上的这篇文章中,它说最大存储大小为2 ^ 31-1字节:
varbinary [(n | max)]
可变长度的二进制数据.n可以是1到8,000之间的值.max表示最大存储大小为2 ^ 31-1个字节.存储大小是输入数据的实际长度+ 2个字节.输入的数据长度可以是0个字节.varbinary的ANSI SQL同义词是二进制变量.
那么如何在varbinary字段中存储更大的文件呢?我不打算使用FILESTREAM,因为我要保存的文件最大为200kb到1mb,我正在使用的代码:
UPDATE [table]
SET file = ( SELECT * FROM OPENROWSET ( BULK 'C:\A directory\A file.ext', SINGLE BLOB) alias)
WHERE idRow = 1
Run Code Online (Sandbox Code Playgroud)
我已经能够成功地将该代码执行到小于或等于8000字节的文件.如果我尝试使用8001字节大小的文件,它将失败.我在表上的文件字段有一个名为"文件"类型的字段varbinary(8000),正如我所说,我无法更改为更大的值.
Aar*_*and 15
我无法重现这种情况.我尝试了以下方法:
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;
Run Code Online (Sandbox Code Playgroud)
结果:
--------
39578
Run Code Online (Sandbox Code Playgroud)
如果这个上限为8K,那么我猜以下任何一个都是真的:
该列实际上是VARBINARY(8000).
您正在Management Studio中选择数据,并分析在那里显示的数据的长度.对于文本,结果限制为最多8192个字符,如果是这种情况,因此DATALENGTH()直接使用该列是一种更好的方法.
| 归档时间: |
|
| 查看次数: |
36078 次 |
| 最近记录: |