加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 08:29:47 所属栏目:MsSql教程 来源:网络整理
导读:有类似的问题,但答案不是我想要的.如果引用为NULL或尚未分配值,我想将值NULL插入SQL Server数据库.目前我正在测试null,它看起来像 String testString = null;if (testString == null){ command.Parameters.AddParameter(new SqlParameter("@column",DBNull.Va
有类似的问题,但答案不是我想要的.如果引用为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.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读