c# - linq - 为绘图填写稀疏表

标签 c# linq

我有一个表,其中包含事件 ID pk、日期列和事件类型列。 我想使用 linq 来获取每天的事件数。 问题是该表是稀疏的,即值不会存储在没有任何事件的日子里。

因为我想将此数据用于折线图,所以我需要用缺失的日期填充数据并将它们的值设为零。

这些是在 linq 中执行此操作的任何方法吗?还是我必须手动执行此操作?

有什么推荐的方法吗?

编辑:

我创建了以下方法:

public string GetDailyData(int month, int year)
    {
        int days = DateTime.DaysInMonth(year,month);
        DateTime firstOfTheMonth = new DateTime(year, month, 1);
        PaymentModelDataContext db = new PaymentModelDataContext();
        var q = from daynumber in Enumerable.Range(0, days)
                let day = firstOfTheMonth.AddDays(daynumber)
                join data in db.TrackingEvents on day equals data.timestamp.Day into d2
                from x in d2.DefaultIfEmpty()
                select Tuple.Create(x.Key, x.Value);

        return ParseJson(q);
    }

问题是我在“join”关键字上遇到错误: “连接子句中的一个表达式的类型不正确。调用‘GroupJoin’时类型推断失败”

编辑 2: 我进行了建议的更改并尝试对结果进行分组。 当我将它们发送到解析函数时,我收到一个空对象引用错误。 这是新代码:

[WebMethod]
    public string GetDailyData(int month, int year)
    {
        int days = DateTime.DaysInMonth(year, month);
        DateTime firstOfTheMonth = new DateTime(year, month, 1);
        PaymentModelDataContext db = new PaymentModelDataContext();
        var q = from daynumber in Enumerable.Range(0, days)
                let day = firstOfTheMonth.AddDays(daynumber)
                join data in db.TrackingEvents on day equals data.timestamp.Date into d2
                from x in d2.DefaultIfEmpty()
                group x by x.timestamp.Date;

        return ParseJson(q);
    }

以及解析函数:

private string ParseJson<TKey, TValue>(IEnumerable<IGrouping<TKey, TValue>> q)
    {
        string returnJSON = "[{ \"type\" : \"pie\", \"name\" : \"Campaigns\", \"data\" : [ ";
        foreach (var grp in q)
        {
            double currCount = grp.Count();
            if (grp.Key != null)
                returnJSON += "['" + grp.Key + "', " + currCount + "],";
            else
                returnJSON += "['none', " + currCount + "],";
        }
        returnJSON = returnJSON.Substring(0, returnJSON.Length - 1);
        returnJSON += "]}]";

        return returnJSON;
    }

最佳答案

您应该能够使用 LINQ。一种方法是使用 Enumerable.Range 创建最小日期和最大日期之间的日期集合,然后对稀疏表执行外部联接(使用 GroupJoin)。 (参见 MSDN Reference: How to Perform Outer Joins (C# Programming Guide))

例如,如果 numdays 是日期范围(以天为单位),MinDate 是初始日期,SparseData 是您的稀疏数据,并且 SparseData 有一个实例属性 Day 指定日期,那么你可以这样做:

var q = Enumerable.Range(0, numdays)
        .Select(a => MinDate.AddDays(a))
        .GroupJoin(
           SparseData,
           q=>q,
           sd=>sd.Day,
           (key, value) =>
               Tuple.Create(
                     key,
                     value.DefaultIfEmpty().First()
               )
          );

或者,等价地,

  var q2 = from daynumber in Enumerable.Range(0, numdays)
           let day = MinDate.AddDays(daynumber)
           join data in SparseData on day equals data.Day into d2
           from x in d2.DefaultIfEmpty()
           select Tuple.Create(x.Key, x.Value);

关于c# - linq - 为绘图填写稀疏表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7049047/

相关文章:

c# - 使用 XtraGrid Entity Framework 创建主/细节网格

c# - 多次处理对象

xml - 我无法读取 xdocument 中的子元素

c# - Lambda 的 LINQ 查询语法

c# - 循环访问 IQueryable 的属性

c# - 在 linq to sql 中使用 this.ExecuteMethodCall 调用存储过程后,全局临时表不再存在

c# - .Net 中的 Oracle 连接池

c# - 如何判断 PictureBox 的图像是否已更改?

c# - Linq OrderBy 不对原始集合进行排序吗?

.net - 如何使用部分类扩展 ADO.NET Entity Framework 对象?