c# - LINQ 到 SQL : Select count rows for each date in a provided range?

标签 c# linq linq-to-sql

我有一个表帐户,其中有一列名为 CreatedOn(可为空的日期时间)。

我正在编写一个方法,它接受两个参数 from 和 to(DateTime 对象),我想选择 from 和 to 之间的所有日期以及在每个日期创建的 T 中的行数。

我怎样才能在 LINQ 中以优雅有效的方式做到这一点?

我试着这样做,但它似乎为列表日期中的每个日期查询一次数据库:

static void Test(DataClasses1DataContext context, DateTime from, DateTime to)
{
    List<DateTime> dates = new List<DateTime>();
    while (from <= to)
    {
        dates.Add(from.Date);
        from = from.AddDays(1);
    }

    var result = dates.Select(d => new { Date = d, Count = context.Accounts.Count(a => a.CreatedOn.HasValue && a.CreatedOn.Value.Date == d) });
    foreach (var row in result)
            Console.WriteLine(row.Date + "   " + row.Count);
}

最佳答案

已根据评论更新

我不会说它优雅,但它只查询一次数据库。

static void Test(DataClasses1DataContext context, DateTime fromDate, DateTime toDate)
{
    var result = context.Accounts
                .Where(p => p.CreatedOn >= fromDate && p.CreatedOn <= toDate)
                .GroupBy(x => x.CreatedOn.Date)
                .Select(x => new {
                   dt = x.Key,
                   count = x.Count()});
}

List<DateTime> dates = new List<DateTime>();
while (fromDate <= toDate)
{
    dates.Add(fromDate.Date);
    fromDate = fromDate.AddDays(1);
}    

var allDates = dates.Select(x => new {
                    dt = x,
                    count = 0});

// Merge both lists and then filter to include highest count
var result = rows.Concat(allDates)
                 .GroupBy(x => x.dt)
                 .Select(x => new {
                    dt = x.Key,
                    count = x.OrderByDescending(c => c.count)
                             .FirstOrDefault().count});

关于c# - LINQ 到 SQL : Select count rows for each date in a provided range?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7877144/

相关文章:

c# - 根据c#中的客户端分辨率调整网页大小

c# - 无论如何要从基于 .Where() linq 子句的集合中删除 (.RemoveWhere() ?)

c# - 在程序执行期间将只读数据库表保存在局部变量中

c# - Linq连接查询错误

linq-to-sql - LINQ to SQL DataContext 缓存

c# - 单个表达式中多个聚合值的 Linq-to-SQL 语句

c# - 区域注册在 MVC Razor 中不起作用

c# - Controller MVC 中的全局变量

c# - 将 SQL 转换为 Linq left join with null

wpf - MVVM Linq2Sql 和 DataContext