1

我在 C# 中使用SqlConnectionandSqlCommand将字符串行(通过Parameters.AddWithValue)插入到 SQL Server 中。我需要插入的一列是Varbinary. 有没有办法在 C# 或 SQL Server 中进行转换?

4

1 回答 1

2

根据this answer,您可以使用该CONVERT函数将字符串插入VARBINARY列中。确保使用正确的编码,如该答案中所述。

insert Table_2 (Test) values( CONVERT(varbinary(30), N'this is a test') ) 
select * from Table_2
select CONVERT(nvarchar(30), test) from Table_2

所以 C# 代码看起来像

    // Get from config
    string connectionString = "";

    using (var conn = new SqlConnection(connectionString))
    {
        string sql = "insert Table_2 (Test) values( CONVERT(varbinary(30), @nvarcharParam) )";
        using (var cmd = new SqlCommand(sql, conn))
        {
            var param = cmd.Parameters.AddWithValue("nvarcharParam", "This is a test");
            param.DbType = DbType.String;

            cmd.ExecuteNonQuery();
        }
    }
于 2013-04-10T21:00:55.290 回答