测试Linq GroupBy DateTime时间3种方式的性能表现

先说结论:

按日期分组时,优先考虑用字符串方式对日期分组

var result = query.GroupBy(
		x => x.Time.ToString("yyyy/MM/dd"),
		(key, models) => new Output
		{
		    Date = key,
		    Count = models.Count()
		});


1.Linq GroupBy 匿名类型:

代码:

按日期分组并且计数

var result = query.GroupBy(
		x => new { x.Time.Date, x.Time.Date.Hour },
		(key, models) => new Output
		{
			Date = key.Date.ToString("yyyy/MM/dd HH"),
			Count = models.Count()
		})
		.ToList();

在这里插入图片描述

结果:

耗时大约836ms


2.Linq GroupBy dynamic:

代码:

//根据参数生成不同分组方式
Func<DashboardModel, dynamic> keySelector = null;
string dateFormat = null;
if (input.GroupByType == "days")
{
    keySelector = x => new { x.Time.Date };
    dateFormat = "yyyy/MM/dd";
}
else
{
    keySelector = x => new { x.Time.Date, x.Time.Date.Hour };
    dateFormat = "yyyy/MM/dd HH";
}
// 按日期分组并且计数
var result = query.GroupBy(
		keySelector,
		(key, models) => new Output
		{
		    Date = key.Date.ToString(dateFormat),
		    Count = models.Count()
		})
		.ToList();

在这里插入图片描述

结果:

耗时大约6s,性能明显下降


3.Linq GroupBy string:

代码:

//根据参数生成不同分组方式
string dateFormat = null;
if (input.GroupByType == "days")
{
    dateFormat = "yyyy/MM/dd";
}
else
{
    dateFormat = "yyyy/MM/dd HH";
}
}
// 按日期分组并且计数
var result = query.GroupBy(
		x => x.Time.ToString(dateFormat),
		(key, models) => new Output
		{
		    Date = key,
		    Count = models.Count()
		})
		.ToList();

在这里插入图片描述

结果:

耗时大约794ms,性能明显提升


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值