.Net从变量值将NULL值插入SQL Server数据库

前端之家收集整理的这篇文章主要介绍了.Net从变量值将NULL值插入SQL Server数据库前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有类似的问题,但答案不是我想要的.如果引用为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.

猜你在找的MsSQL相关文章