35
param7[1].Value = tbLastName.Text.Length > 0 ? tbLastName.Text : DBNull.Value;

为什么这是不可能的,还有什么建议可以尝试?20 个参数的 if/else 不是办法。

4

1 回答 1

78

问题是(如错误消息所示)条件表达式需要两个分支上的类型相同,或者需要从一种类型到另一种类型的隐式转换。在你的情况下,没有一个,所以你得到了错误。一种快速修复方法是将其中一个值转换为(object)(这很好,因为无论如何DbParameter.Value都是类型。)object

所以这应该适合你:

param7[1].Value = tbLastName.Text.Length > 0 ? tbLastName.Text : (object)DBNull.Value;
于 2013-05-12T01:27:20.210 回答