我有一个表Employee
,其中SQL列中的列为Id(bigint)
和DocumentContent(varbinary(MAX))
。提取二进制数据时存储的空值
现在,当我尝试在使用XML的Employee
表中插入记录时,Null
值存储在大小小于1Kb
的文件的表中。当文件大小大于1Kb
时,它将被转换为二进制数据并存储在数据库中。产生
我的XML如下:
<MyDocuments>
<Rows>
<Id>62</Id>
<Document_Content>104116116112584747495550464954464846495856485748471041161161129910810510111011646104116109108</Document_Content>
</Rows>
</MyDocuments>
和存储过程
CREATE Procedure [dbo].[Proc_SaveDocuments]
(
@XMLData as XML
)
AS
BEGIN
Declare @propertyCount Varchar(100) = '',@currentCount int=1,@Id bigint,@Content varbinary(MAX)
SELECT @propertyCount = convert(VARCHAR, @XMLData.query ('count(/MyDocuments/Rows)'))
SET @currentCount = 1
WHILE (@currentCount<[email protected])
BEGIN
SET @Id = @XMLData.value('data(/MyDocuments/Rows[sql:variable("@currentCount")]/Id)[1]', 'BIGINT')
SET @Content = @XMLData.value('data(/MyDocuments/Rows[sql:variable("@currentCount")]/Document_Content)[1]', 'VARBINARY(MAX)')
insert into Employee values(@Id,@Content) --inserts null in DocumentContent column when file size less than 1Kb, else converts it to binary and saves it in database.
SET @currentCount = @currentCount + 1
END
END
任何想法,为什么会出现这种情况,如何可以这样解决?
多少在被插入空1K的文件? –
tale852150
@ tale852150:它可以是任意数量的行,1或多于1 .. –