如何提高此EF代码的速度?
我正在填写trperday
词典,具有〜2700的值,需要几秒钟。这些数据库查询可以通过某种方式优化吗?
// transactions per day
SortedDictionary<DateTime, int> trPerDay = new SortedDictionary<DateTime, int>();
foreach (Order order in orders)
{
foreach (OrderDetail od in order.OrderDetails)
{
int qty = CommonUtils.ComputeQuantity(od);
DateTime date = order.date.Date;
if (!trPerDay.ContainsKey(date))
{
trPerDay.Add(date, qty);
}
else
{
trPerDay[date] += qty;
}
}
}
I'm filling the trPerDay
dictionary with ~2700 values and it takes several seconds. Can these DB queries be optimized in some way?
// transactions per day
SortedDictionary<DateTime, int> trPerDay = new SortedDictionary<DateTime, int>();
foreach (Order order in orders)
{
foreach (OrderDetail od in order.OrderDetails)
{
int qty = CommonUtils.ComputeQuantity(od);
DateTime date = order.date.Date;
if (!trPerDay.ContainsKey(date))
{
trPerDay.Add(date, qty);
}
else
{
trPerDay[date] += qty;
}
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我知道您想按日期获得订单详细信息
I understand that you want to get order details count by date
最低限度,当您加载订单时,请确保急切地加载OrderDetails,以避免每次订单的懒惰负载。这是假设您的计算性非常复杂,并且不能将其表达为LINQ计算。
如果可以计算LINQ表达式中的数量,则可以通过执行
groupby
来大大改进查询性能。例如:这里的捕获是,必须在 expression expression中表达订单详细信息的逻辑,而无需执行诸如声明c#函数以计算它之类的事情。 EF必须能够将表达式转换为SQL。这看起来不像将其分为单独的方法那样“干净”,但是差异允许数据库进行计算,可能是下秒的时间与秒或更高(随着系统的大小增长)进行计算在记忆中获取后,所有适用的订单和订单详细信息首先进入内存。
At a bare minimum, when you load orders, be sure to eager load the OrderDetails to avoid a lazy load hit for each order. This assumes that your ComputeQuantity is prohibitively complex and cannot be expressed down into a Linq calculation.
If it is possible to compute the Quantity within a linq expression, the query performance can be drastically improved by doing a
GroupBy
. For example:The catch here is that the logic to determine what order details to include has to be expressed in a
Where
expression without doing something like declaring a C# function to compute it. EF has to be able to translate the expression down to SQL. This may not look as "clean" as separating it off into a separate method, but the difference is allowing the database do do the computation is likely sub-second time vs. seconds or more (as the system grows in size) doing the computation in memory after fetching all applicable orders and order details into memory first.