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字段中存储更大的文件呢?我不打算使用FILESTREAM,因为我要保存的文件最大为200kb到1mb,我正在使用的代码: UPDATE [table] SET file = ( SELECT * FROM OPENROWSET ( BULK 'C:A directoryA 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:FolderFile.docx',SINGLE_BLOB) alias ); SELECT DATALENGTH(col) FROM dbo.blob; 结果: -------- 39578 如果这个上限为8K,那么我猜以下任何一个都是真的: >该列实际上是VARBINARY(8000).>您正在Management Studio中选择数据,并分析在那里显示的数据的长度.对于文本,结果限制为最多8192个字符,如果是这种情况,因此直接对列使用DATALENGTH()是一种更好的方法. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |