C# 如何在Linq to sql中仅获取group by语句中的日期
如何在LINQ中通过语句仅获取group by中的日期C# 如何在Linq to sql中仅获取group by语句中的日期,c#,linq,linq-to-sql,C#,Linq,Linq To Sql,如何在LINQ中通过语句仅获取group by中的日期 var res = query.GroupBy( b => b.CreatedDate.ToString() ).Select(c => new { ShredQueueCount = c.Sum(w => w.ShredQueueCount), ShredCompletedCount = c.Sum(w
var res = query.GroupBy( b => b.CreatedDate.ToString() ).Select(c => new
{
ShredQueueCount = c.Sum(w => w.ShredQueueCount),
ShredCompletedCount = c.Sum(w => w.ShredCompletedCount),
ShredValFailureCount = c.Sum(w => w.ShredValFailureCount),
ShredExceptionCount = c.Sum(w => w.ShredExceptionCount),
CreatedDate = c.Select(w => w.CreatedDate)
});
如果它是一个LINQ表达式,将由SQL Server端的LINQ to SQL使用,那么您需要: 否则,对于LINQ to对象,您可以使用:
query.GroupBy(b => b.CreatedDate.Date)
如果字段的类型为Nullable,则可以执行以下操作:
query.GroupBy(b => b.CreatedDate.DefaultIfEmpty().Date)
这将忽略DateTime字段中的时间部分 我只想按日期分组。@nimishjain,你的意思是只按日期而不是时间吗?@nimishjain,我已经修改了答案,你需要:query.GroupByb=>b.CreatedDate.date,我看不到日期在b=>b之后。CreatedDate@nimishjain,将LINQ的答案修改为SQL。您看不到日期,因为CreatedDate是可空的
query.GroupBy(b => b.CreatedDate.DefaultIfEmpty().Date)