【问题标题】:saving bytearray to VarBinary column in SQL Server inserts only one byte将 bytearray 保存到 SQL Server 中的 VarBinary 列仅插入一个字节
【发布时间】:2015-04-23 13:06:54
【问题描述】:

我遇到以下问题 - 我正在尝试将 byte[] 保存到数据库中,但我发现它仅适用于一个字节。

我有许多浮点数,我转换为 byte[] 并将其用作参数:

param = new SqlParameter(name, type, ((byte[])value).Length);

type 为VarBinary,value 为字节数组。

我将该参数添加到我的SqlCommand 中,就在它被执行之前,整个字节数组“位于”该参数中,并且该参数的_msize 是正确的(我假设 20 个字节代表 20 个字节是正确的)。我的 SQL Server 显示我只保存了 1 个字节,还试图取回它我只得到一个字节。我的专栏是VarBinary(200)

有什么建议吗?

【问题讨论】:

  • 认为这篇文章中的答案会做到这一点:stackoverflow.com/questions/1064121/…
  • 差不多就是这样。也许这个问题应该因为重复而被关闭。
  • 显示设置参数值的代码。

标签: c# sql-server bytearray varbinary


【解决方案1】:

如果您使用的是存储过程,并且您已将参数定义为 varbinary - 根据 MSDN documentation,您将获得 1 字节 的默认长度:

当 n 在数据定义或变量声明语句中未指定时,默认长度为 1。当 CAST 函数未指定 n 时,默认长度为 30。

所以如果你有一个存储过程

@MyData VARBINARY

那么您只有一个字节 - 您需要将其更改为类似

@MyData VARBINARY(200) 

或者其他适合你的东西

【讨论】:

  • @JoelCoehoorn:是的 - 在 C# 中 - 但是如果 C# 代码调用使用该参数 没有 长度的 T-SQL 存储过程怎么办? C# 有长度和所有 - 但在 T-SQL 存储过程中,你得到 1 字节 of varbinary 数据 ....
  • 解决问题根源的优秀答案!它也可以设置为 varbinary(max)。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2010-12-10
  • 2017-10-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多