从DataRow(C#)检索DateTime值

时间:2009-07-09 20:14:07

标签: c# datetime ado.net

如何从行中获取C#中的DateTime值,当前代码给出了错误 任何帮助表示赞赏,数据来自进度数据库:

foreach (DataRow r in ds.Tables[0].Rows)
{
    string prodCode = r["PRD-CDE"].ToString();
    statCode = r["STAT"].ToString();
    DateTime firstIssueDate = (DateTime)(r["FISS"]); 
    DateTime endIssueDate = (DateTime)(r["EISS"]);
    if(endIssueDate > DateTime.Now)
    { /*do some thing...*/}
    else {/*user invalid...*/}
}

有两种方法可用于获取日期转换和分析,谢谢大家的帮助

最终工作代码段

foreach (DataRow r in ds.Tables[0].Rows)
            {
                string prodCode = r["PRD-CDE"].ToString(),statCode = r["STAT"].ToString();
               // r.<DateTime?>("FISS");
                if (r["FISS"] != DBNull.Value)
                {
                    DateTime firstIssueDate = Convert.ToDateTime(r["FISS"]);
                    if (r["EISS"] != DBNull.Value)
                    {
                        DateTime endIssueDate = DateTime.Parse(r["EISS"].ToString());
                        if (endIssueDate > DateTime.Now)
                        {

8 个答案:

答案 0 :(得分:38)

这只是猜测,但如果数据库中的相应类型是DateTime,你能检查一下该列是否可以为空吗?

如果是这样,您可能需要检查r["column"] == DBNull.Value然后将其传递给可以为空的DateTime?字段。

甚至更容易:

row.Field<DateTime?>("column")

如果不是那么是,Convert.ToDateTime()或其他东西应该这样做。

修改

我在那里看到了你的最终代码,但你有没有想要这样做:

DateTime? firstIssueDate = r.Field<DateTime?>("fiss"); 
DateTime? endIssueDate = r.Field<DateTime?>("eiss"); 

if (firstIssueDate.HasValue && endIssueDate.HasValue) 
{ 
    firstIssueDate.Value // blah blah 
    endIssueDate.Value // blah blah 
}

答案 1 :(得分:11)

如果行返回该索引的字符串,我建议使用DateTime.Parse()。

 string prodCode = r["PRD-CDE"].ToString(),statCode = r["STAT"].ToString();
 DateTime firstIssueDate = DateTime.Parse(r["FISS"].ToString());
 DateTime endIssueDate = DateTime.Parse(r["EISS"].ToString());

您也可以根据需要使用TryParse

答案 2 :(得分:5)

如果要使用默认值(例如DateTime.MinValue)而不是null(DateTime?)或DBNull,则可以执行以下操作:

var firstIssueDate = r["FISS"] as DateTime? ?? DateTime.MinValue;
var endIssueDate = r["EISS"] as DateTime? ?? DateTime.MinValue;

答案 3 :(得分:2)

foreach (DataRow r in ds.Tables[0].Rows)
{
    string prodCode = r["PRD-CDE"].ToString();
    string statCode = r["STAT"].ToString();
    DateTime firstIssueDate = DateTime.Parse((r["FISS"]).ToString()); 
    DateTime endIssueDate = DateTime.Parse((r["EISS"]).ToString());
    if(endIssueDate > DateTime.Now)
    { /*do some thing...*/}
    else {/*user invalid...*/}
}

这应该编译并可能适合您。虽然它肯定没有执行任何错误检查,你应该为生产代码。另请查看DateTime.TryParse,您可以考虑添加IFormatProvider以确保按预期解析格式。

答案 4 :(得分:1)

首先,执行r [“FISS”]。GetType()并将其打印到控制台(或暂停并在调试器中查看)。如果它说它是一个字符串,那么上述大多数建议都会有所帮助。如果它说了别的话,请回来更新你的问题。

答案 5 :(得分:0)

作为旁边的答案,你也可以使用静态函数Convert.ToDateTime

答案 6 :(得分:0)

DateTime.Parse(r [“FISS”]。ToString())是要走的路,但它会抛出“字符串未被识别为有效的DateTime”错误。你能否在r [“FISS”]专栏中显示实际的字符串,这可能是一个国际化问题....

答案 7 :(得分:0)

如果您的DateTime字符串具有需要转换为.NET DateTime类型的特殊格式(不是任何标准.NET DateTime格式),则可以使用DateTime.ParseExact()方法。

请参阅MSDN document了解更多详情,包括示例。

如果要解析多种格式,请尝试DateTime.ParseExact Method (String, String[], IFormatProvider, DateTimeStyles)