如果我创建一个新的OleDbReader,如下所示:
OleDbCommand command = new OleDbCommand(query, ActiveConnection);
reader = command.ExecuteReader();
while(reader.Read())
{
someList.Add((double)reader["columnHeader"]);
}如果返回的数据被键入为Int32 16/Int32 32/Int32 64而不是double,那么如何确保总是从指定的列返回Double?是否必须为每种可能的类型创建一个处理程序?我知道Double.Parse存在,但它只接受字符串。因此,虽然我可以事先使用ToString(),但我觉得这可能不是最直接的类型传递方式。
同样,对于另一列,我希望确保任何字符串/Double/I 16/I 32/I 64值都返回为字符串。ToString()会处理这些案件吗?
我对潜在的溢出错误没有意见,因为我将检查异常。
发布于 2014-01-29 22:07:25
您应该调用Convert.ToDouble(),它对每种类型都有一个处理程序。
相反,ToString()将适用于任何非空值。(只要它覆盖ToString(),所有的数值类型都会)
https://stackoverflow.com/questions/21443685
复制相似问题