我有一个表,其中包含事件 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/