1

当我尝试从数据表中获取列值时,会出现上述错误消息。

这是我在堆栈跟踪中找到的:

System.Linq.Enumerable.WhereSelectEnumerableIterator 1 来源)2.MoveNext()
at System.Linq.Enumerable.FirstOrDefault[TSource](IEnumerable

 and this in the TargetSite when debugging:

{ 布尔 b__0(System.Data.DataRow)}

这是我的代码:DataTable hr = new DataTable();

            hr.Columns.Add("BookingDate");
            hr.Columns.Add("BookingId");
            hr.Columns.Add("BookingSource");
            hr.Columns.Add("CheckInDate");
            hr.Columns.Add("CheckOutDate");


            for (int i = 0; i < gmisc.GetModifiedBookings(gmoreq).Bookings.Length; i++)
            {
                hr.Rows.Add();
                hr.Rows[i]["BookingDate"] = Convert.ToDateTime(gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingDate.ToString());
                hr.Rows[i]["BookingId"] = Convert.ToInt64(gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingId.ToString());
                hr.Rows[i]["BookingSource"] = gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingSource.ToString();
                hr.Rows[i]["CheckInDate"] = Convert.ToDateTime(gmisc.GetModifiedBookings(gmoreq).Bookings[i].CheckInDate.ToString());
                hr.Rows[i]["CheckOutDate"] = Convert.ToDateTime(gmisc.GetModifiedBookings(gmoreq).Bookings[i].CheckOutDate.ToString());



            }
            Int64 BookingId = (from DataRow dr in hr.Rows
                          where (Int64)dr["BookingId"] == BookId
                          select (Int64)dr["BookingId"]).FirstOrDefault();
                TextBox1.Text = Convert.ToString(BookingId);

我哪里错了,如果有人可以告诉我。

4

3 回答 3

1

如果 dr["BookingId"] 从不为空(否则添加空检查)

采用

                  Int64 BookingId = (from DataRow dr in hr.Rows
                        where Int64.Parse(dr["BookingId"].ToString()) ==BookId
                        select Int64.Parse(dr["BookingId"].ToString())).FirstOrDefault();

代替

                  Int64 BookingId = (from DataRow dr in hr.Rows
                      where (Int64)dr["BookingId"] == BookId
                      select (Int64)dr["BookingId"]).FirstOrDefault();
于 2012-05-15T04:10:27.307 回答
1

检查您的代码,前两行:

hr.Rows[i]["BookingDate"] = Convert.ToDateTime(gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingDate.ToString());
hr.Rows[i]["BookingId"] = Convert.ToInt64(gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingId.ToString());

如果 gmisc.GetModifiedBookings(gmoreq).Bookings[i].BookingDate 为空,那么 ??? 您正在尝试将其转换为字符串,然后转换为日期时间

如果为空,则 .ToString 将给出错误“指定成本.......”

在转换为日期时间时也会发生同样的情况。

于 2012-05-15T04:13:39.490 回答
0

当您使用重载创建数据列时Add(string),该列的类型是string(请参阅http://msdn.microsoft.com/en-us/library/52xzw8tf.aspx)。您不能将字符串直接转换为Int64or DateTime

使用Add(string, Type)重载或Add(string, Type, string)重载来指定列数据的类型。

于 2012-05-15T04:06:22.093 回答