无法隐式转换类型System.DateTime?'到' int?' C#Linq

时间:2014-07-14 19:36:12

标签: c# sql linq

代码:它突出了我可以尝试告诉Linq找到shipto列并在另一个表上更新datetimestamp一定时间的最底层部分,并告诉我我不能隐式转换类型'System。约会时间?' 'int?'我不确定如何继续...

  var TestingLinq = (from a in db.shp_master
                     join b in db.shp_status on a.serialnbr equals b.serialnbr into b_join
                     from b in b_join.DefaultIfEmpty()
                     where
                               a.shipto == "1022a" &&
                               a.status == "s" &&
                               b.status == "s" &&
                               a.shpreq == 0
                     group new {a, b} by new {
                               a.serialnbr,
                               a.trailer,
                               a.shipto
                     } into g
                     orderby
                               g.Key.serialnbr
                     select new RecieveTruck {
                               SerialNumber = g.Key.serialnbr,
                               TrailerNumber = (g.Key.trailer ?? "N/A"),
                               Shipped = g.Min(p => p.b.datetimestamp),
                               ETA = 
                               g.Key.shipto == "1026" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) :
                               g.Key.shipto == "2020" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(195) :
                               g.Key.shipto == "2017" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) : 
                               g.Key.shipto == "nor" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) : null
                     });
  return View(TestingLinq);

给我标题中的错误.... 我试图将此SQL查询转换为Linq:

SELECT a.serialnbr, ISNULL(a.trailer, 'N/A') AS 'trailer', MIN(b.datetimestamp) AS 'datetimestamp', 
             CASE WHEN a.shipto = '1026' THEN DATEADD(mi, 180, MIN(b.datetimestamp)) 
                  WHEN a.shipto = '2020' THEN DATEADD(mi, 195, MIN(b.datetimestamp)) 
                  WHEN a.shipto = '2017' THEN DATEADD(mi, 180, MIN(b.datetimestamp)) 
                  WHEN a.shipto = 'nor' THEN DATEADD(mi, 180, MIN(b.datetimestamp)) 
                  ELSE NULL END AS 'eta' 
             FROM shp_master AS a LEFT OUTER JOIN shp_status AS b ON a.serialnbr = b.serialnbr 
             WHERE a.shipto = '1022a' AND a.status = 's' AND b.status = 's' AND a.shpreq = 0 
             GROUP BY a.serialnbr, a.trailer, shipto 
             ORDER BY a.serialnbr    

1 个答案:

答案 0 :(得分:1)

在您的评论中,您指定RecieveTruck.ETAint?,但您通过执行

进行分配
 ETA = g.Key.shipto == "1026" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) :
       g.Key.shipto == "2020" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(195) :
       g.Key.shipto == "2017" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) : 
       g.Key.shipto == "nor" ? (System.DateTime?)Convert.ToDateTime(g.Min(p => p.b.datetimestamp)).AddMinutes(180) : null

这将解析为DateTime?。您需要选择其中一个。看起来你正在寻找ETA成为DateTime?,所以我只是改变了这种属性类型,你应该好好去。