gpt4 book ai didi

c# - 处理数据类型转换的通用函数

转载 作者:行者123 更新时间:2023-11-29 13:29:09 25 4
gpt4 key购买 nike

我在 C# 中有以下函数,我想传递 MySQL DataReader 值/对象。

如果传递的对象的值是 DBNull,我需要处理它并返回该数据类型的 Null 值,例如 null int。

否则我想转换返回的值,如 Convert.ToInt32(value) 或类似的。我的功能是;

public static T ConvertFromDB<T>(object value)
{
return value == DBNull.Value ? default(T) : (T)value;
}

我可以像这样调用函数

int MyInt = ConvertFromDB(oRes["FieldName"]);

但是在这种情况下,oRes["FieldName"] 的 MySQLDataReader 结果是 DBNull,这会导致异常。

任何人都可以提供任何帮助吗?我正在使用强类型列,但我遇到的问题是如果数据库值为 DBNull,我需要返回该数据类型的 null,例如 (int)null

最佳答案

也许您正在寻找 Convert.ChangeType()

return value == DBNull.Value ? default(T) : (T) Convert.ChangeType(value, typeof(T));

请注意,当转换失败时,您将必须处理异常,这使得像这样的扩展方法受到怀疑。

也就是说,如果您正在阅读强类型列,它们应该已经采用您想要的格式。为什么不直接使用 SqlDataReader.GetInt32() (或类似)?如果是因为您想使用 SqlDataReader 按名称引用数据库列的索引运算符,也许您最好使用一组添加重载并调用 GetOrdinal() 的扩展方法。相反,在他们之中。有些人可能会认为这表明存在其他代码味道。

关于c# - 处理数据类型转换的通用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19723604/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com