3

我正在使用较旧的 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

我考虑过使用泛型类来处理所有不同的类型,但我真的想不出最好的方法。

有任何想法吗?

4

2 回答 2

6

我发现以下辅助方法在您的场景中很有用 - 测试 DBNull 比在您的示例中捕获异常更有效:

public static MyHelper
{
    public static Nullable<T> ToNullable<T>(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)。

它与您的示例略有不同,因为它是转换而不是转换 - 但我个人更喜欢这个。即如果数据库列是NUMERIC(十进制),如果我想将值转换为int,我宁愿明确,例如:

int? myIntValue = (int?) MyHelper.ToNullable<decimal>(reader["MyNumericColumn"]);
于 2009-12-17T18:12:47.057 回答
0

您可以引入简单的模型类并在它们之间进行映射。

例如:

public class Customer
{
   public Customer(DataRow row) 
   {
      Name = row["Name"];
   }
   public Name { get; private set; }
}

当然,为了减少重复代码,您可以为模型数据类创建一个基类。

根据您想要花费的精力,您可以使用 ORM 映射器 NHibernate。

于 2009-12-17T18:15:29.690 回答