c# - 如何使 Entity Framework 异步执行

标签 c# asp.net-mvc entity-framework asynchronous

我在 ASP.Net MVC 5 应用程序中遇到异步 Controller 问题。 我正在使用 Entity Framework 6 Code First 方法。

我有一个方法

public async Task<ActionResult> Index()
{
    using(var context = new MyDbContext())
    {
        var eventsTask = context.Events
            .Where(e => e.Enable)
            .ToListAsync();

        var countTask = context.Users
            .CountAsync();

        await Task.WhenAll(eventsTask, countTask);
        return View(new ViewModel()
        {
            Events = eventsTask.Result, 
            Count = countTask.Result
        });
    }
}

我这里有两个异步方法。我已经通过 MiniProfiler 分别测量了它们中的每一个。他们需要大约 85 毫秒。

但在我的方法中,我使用 Task.WhenAll() 运行它们。我相信它会异步执行 Db 查询,并且两者都需要大约 85-90 毫秒。但它需要 ~170-180。所以我有同步运行的异步方法(彼此跟随)。

我认为这是因为上下文。我有一个测试,当我删除上下文查询并使用 HttpClient 调用许多 api 方法时。它花费的时间等于它们中更长的时间(3 个 api 调用,每个调用约 500 毫秒。整个方法需要约 600 毫秒)。我相信可以异步执行 EF 方法。

谁知道解决办法

最佳答案

这实际上应该不起作用,而是抛出一个异常。我猜第一个查询甚至在第二个查询开始之前就完成了。

EF6 doesn't support multiple async operations on the same context.

要么 await 每个查询(因此它们不会同时运行),要么为每个查询使用不同的上下文。

关于c# - 如何使 Entity Framework 异步执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24701960/

相关文章:

c# - Gtk# 中是否有文件夹浏览器小部件?

c# - 插件架构

c# - 如何从 C# 代码注销 Blazor 服务器

c# - NServiceBus.Azure 和 EF SqlAzureExecutionStrategy

entity-framework - Entity Framework - 迁移 - @objname 不明确

c# - 可以替代链式开关/转到的设计模式?

asp.net-mvc - 空项目中缺少类型 Mono.Web.Util.RoleManagerSectionMapper

c# - ASP.NET EnumDropDownListFor 生成 DropDown 但不选择模型的值

c# - 获取 View 中的当前用户的 ASP.NET 标识

c# - 什么是 Entity Framework fluent api?