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

正确的方法来取消装箱数据库值

如何解决《正确的方法来取消装箱数据库值》经验,为你挑选了1个好方法。

我有一个较旧的Oracle数据库的工作,我觉得有可能是一个更好的方式去了解我拆箱从数据库中检索值.

目前,我有一个充满不同类型特定方法的静态类:

public static int? Int(object o)
{
    try
    {
        return (int?)Convert.ToInt32(o);
    }
    catch (Exception)
    {
        return null;
    }
}

..等等,对于不同的类型,但我觉得应该有更好的方法?如果我想取消装箱值,我会做一些......

int i;
i = nvl.Int(dataRow["column"]); //In this instance, "column" is of a numeric database type

我想过使用泛型类来处理所有不同的类型,但我无法找到最佳方法.

有任何想法吗?



1> Joe..:

我发现辅助方法如下面的方案中有用 - 测试DBNull比在示例中捕获异常更有效:

public static MyHelper
{
    public static Nullable ToNullable(object value) where T : struct
    {
        if (value == null) return null;
        if (Convert.IsDBNull(value)) return null;
        return (T) value;
    }

    public static string ToString(object value)
    {
        if (value == null) return null;
        if (Convert.IsDBNull(value)) return null;
        return (string)value;
    }
}

这适用于您将遇到的字符串和常用的原始值类型(int,decimal,double,bool,DateTime).

它与你的例子略有不同,因为它是演员而不是转换 - 但我个人更喜欢这个.也就是说,如果数据库列是数字(十进制),我宁愿是明确的,如果我想的值转换为int,例如:

int? myIntValue = (int?) MyHelper.ToNullable(reader["MyNumericColumn"]);

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