当前位置:  开发笔记 > 编程语言 > 正文

C#ADO.NET:nulls和DbNull - 是否有更高效的语法?

如何解决《C#ADO.NET:nulls和DbNull-是否有更高效的语法?》经验,为你挑选了4个好方法。



1> Stewart John..:

啊哈!我找到了比@ Trebz更有效的解决方案!

datePrm.Value = nullableDate ?? (object)DBNull.Value;



2> Gian Marco G..:

如果您使用的是SQLServer,则System.Data.SqlTypes命名空间包含一些避免恼人的类型转换的实用程序类.例如,而不是这样:

var val = (object) "abc" ?? DBNull.Value;

你可以这样写:

var val = "abc" ?? SqlString.Null;



3> dnolan..:

如果你使用它会工作

datePrm.Value = nullableDate.HasValue ? (object)nullableDate.Value : DBNull.Value;



4> Pop Catalin..:

如果您使用的是C#3.0,则可以创建一个扩展方法来轻松实现:

public static class DBNullableExtensions
{
    public static object ToDBValue(this Nullable value) where T:struct
    { 
        return value.HasValue ? (object)value.Value : DBNull.Value;
    }
}


class Program
{
    static void Main(string[] args)
    {
        int? x = null;

        Console.WriteLine(  x.ToDBValue() == DBNull.Value );
    }
}

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