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()是一种更好的方法. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- SQL SERVER一句Sql把纵向表转为横向表,并分别分组求平均和
- 计算机二级考试MySQL知识点 mysql alter命令
- sql-server-2005 – 从SQL Server 2008降级到2005
- sql server:删除所有表的所有行
- sql-server – SQL Server FOR XML PATH:在顶部设置xml-de
- 详解MySQL导出指定表中的数据的实例
- sql – 检查所有行的列值是否正好是值
- sql-server – 如何在JetBrains DataGrip中连接到MS SQL Se
- sql-server – SSRS:如何计算真行
- 表创建时sql – IDENTITY NOT NULL
