有类似的问题,但答案不是我想要的.如果引用为NULL或尚未分配值,我想将值NULL插入sql Server数据库.目前我正在测试null,它看起来像
String testString = null; if (testString == null) { command.Parameters.AddParameter(new sqlParameter("@column",DBNull.Value); } else { command.Parameters.AddParameter(new sqlParameter("@column",testString); }
这看起来和我觉得非常笨拙.我有很多值,我插入数据库并测试它们所有像上面这样非常详细. .Net不会以某种方式处理这个问题.我想也许如果我使用字符串而不是字符串,但这似乎也不起作用.环顾四周,我找到了有关使用Nullable类型的文章.
System.Nullable<T> variable
这似乎适用于原语,int?,char?双?和布尔?这可能适用于那些但是字符串呢?我在这里错过了一些东西.我应该使用什么类型的原始值和字符串值,以便我不必在插入之前重复测试值.
编辑:
在我得到关于三元运算符的太多答案之前.我喜欢他们但不喜欢这种情况.对于我来说,需要测试该值并拥有所有额外的逻辑是没有意义的,当这种事情可以在.Net框架中降低时,如果我知道要给出的类型那么它就会得到它免费.
编辑:
好的,所以大家帮我制定攻击计划.我将使用Nullable作为我的原语(int?,double?etc),对于我的Strings,我将使用String但是??测试.这使事情变得不那么冗长.我在这里缺少什么,比如可能会失去一些语义?
解决方法
甚至比三元组更好的是双问号(??)运算符.采用第一个非空值.所以:
string x = null; command.Parameters.AddParameter( new sqlParameter("@column",(object)x ?? DBNull.Value);
会给你一个值为DBNull.Value的parm,但是
string x = "A String"; command.Parameters.AddParameter( new sqlParameter("@column",(object)x ?? DBNull.Value);
会给你一个“A String”作为值的parm.