当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《.Net从变量值将NULL值插入SQLServer数据库》经验,为你挑选了1个好方法。

有类似的问题,但答案不是我想要的.如果引用为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 variable

这似乎适用于原语,int?,char?双?和布尔?这可能适用于那些但是字符串呢?我在这里错过了一些东西.我应该使用什么类型的原始值和字符串值,以便我不必在插入之前重复测试值.

编辑:在我得到关于三元运算符的太多答案之前.我喜欢他们但不喜欢这种情况.对于我来说,需要测试该值并拥有所有额外的逻辑是没有意义的,当这种事情可以在.Net框架中降低时,如果我知道要给出的类型那么它就会得到它免费.

编辑: 好的,所以大家帮我制定攻击计划.我将使用Nullable作为我的原语(int?,double?etc),对于我的Strings,我将使用String但是?? 测试.这使事情变得不那么冗长.我在这里缺少什么,比如可能会失去一些语义?



1> Walden Lever..:

甚至比三元组更好的是双问号(??)运算符.采用第一个非空值.所以:

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.

推荐阅读
贴进你的心聆听你的世界
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有