我正在尝试使用 sql 客户端将空""
或null
值从 C# 更新到始终加密的列中;但是我得到以下错误。如果我传递一个空格" "
它就可以了.
错误:
nvarchar(4000( 加密 (encryption_type = 'DETERMINISTIC', encryption_algorithm_name = 'AEAD_AES_256_CBC_HMAC_SHA_256', column_encryption_key_name = 'CEK', column_encryption_key_database_name = 'db'(与加密的 nvarchar(50( 不兼容 (encryption_type = 'DETERMINISTIC', encryption_algorithm_name = 'AEAD_AES_256_CBC_HMAC_SHA_256', column_encryption_key_name = 'CEK', column_encryption_key_database_name = 'db'(
工作代码如下:
SqlConnection connection = new SqlConnection(dbString);
connection.Open();
SqlParameter p = new SqlParameter("@lastname", System.Data.SqlDbType.NVarChar, 50);
p.Value = string.Empty;
SqlCommand command = new SqlCommand("update associate set lastname=@lastname", connection);
command.Parameters.Add(p);
command.ExecuteNonQuery();
connection.Close();
问题是客户端参数定义必须与服务器上的加密列类型完全匹配。