DataTable,byte []字段作为存储过程的参数

时间:2012-09-18 18:17:00

标签: c# .net datatable table-valued-parameters

我一直在重用这种使用DataTable作为存储过程参数的方法,并且它一直运行良好。这是简化的工作代码:

using (dbEntities dbe = new dbEntities())
{
    var dt = new dataTable();
    dt.Columns.Add("ID");
    dt.Columns.Add("Message");
    dt.Columns.Add("CreatedOn", typeof(DateTime));

    foreach (var row in randomDataSource)
    {
        dt.Rows.Add(
            row.id,
            row.message,
            DateTime.Now
            );
    }

    var tableType = new SqlParameter("tableType", SqlDbType.Structured);
    tableType.Value = dt;
    tableType.TypeName = "[dbo].[RandomTableType]";

    dbe.ExecuteStoreCommand(
        "EXEC [dbo].[SaveTable] @tableType",
        new object[] { tableType }
        );
}

当我想要添加的字段是二进制类型时,会出现问题。即:

dt.Columns.Add("BinaryMessage", typeof(byte[]));

顺便说一下,数据库中的相应列是varbinary(MAX)。当我尝试运行它时,我收到此错误:

  

从数据类型nvarchar(max)到varbinary(max)的隐式转换是   不允许。使用CONVERT函数运行此查询。

如何修改我的工作?

1 个答案:

答案 0 :(得分:10)

.NET中二进制字符串的表示形式为SqlBinary structure

您希望像这样添加列:

dt.Columns.Add("BinaryMessage", typeof(SqlBinary));

SqlBinary类有一个explicit conversion to a byte array和一个implicit conversion from a byte array,所以从一个字节数组到列的值是一个简单的赋值问题,同时从列中获取一个字节数组需要明确的演员。