簡體   English   中英

使用C#更新sql server`varbinary`列時出現問題

[英]Issue in updating a sql server `varbinary` column using C#

當我編寫插入代碼時,一切都很好。 例如:

dataCommand.CommandText = "use mydb; INSERT INTO mytable VALUES(@binaryvalue);
dataCommand.Parameters.Add("@binaryvalue", SqlDbType.VarBinary, 256).Value = mycard;
dataCommand.ExecuteNonQuery();

但是,如果我嘗試更新,它將無法正常工作。 我使用.WRITE方法,但它不會這樣做:

dataCommand.CommandText = "use mydb; update mytable set mycolumn .Write(@binaryvalue, 0, NULL) where myid = " + wid;
dataCommand.Parameters.Add("@binaryvalue", SqlDbType.VarBinary, 256).Value = mycard;
dataCommand.ExecuteNonQuery();

如何執行更新而不是刪除/插入?

謝謝你的回復!

也許問題是NULL

.WRITE (expression,@Offset,@Length)         (reference)
.Write(@binaryvalue, 0, NULL)               (your code)

嘗試將內容的長度替換為NULL

@Length是列中節的長度,從@Offset開始,由表達式替換。 @Length是bigint,不能是負數。 如果@Length為NULL,則更新操作會將@Offset中的所有數據刪除到column_name值的末尾。

更多信息: http//msdn.microsoft.com/en-us/library/ms177523.aspx

表中二進制列的確切類型是什么? 是VARBINARY(MAX)? 如果沒有,請嘗試一下,看看它是否有效。 根據文件:

“使用.WRITE(expression,@ Offset,@ Length)子句執行varchar(max),nvarchar(max)和varbinary(max)數據類型的部分或完全更新”

“要與其他字符或二進制數據類型實現.WRITE的相同功能,請使用STUFF(Transact-SQL)。”

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM