Salvamento assíncronoAsynchronous Saving

O salvamento assíncrono evita o bloqueio de um thread enquanto as alterações são gravadas no banco de dados.Asynchronous saving avoids blocking a thread while the changes are written to the database. Isso pode ser útil para evitar o congelamento da interface do usuário de um aplicativo de cliente espesso.This can be useful to avoid freezing the UI of a thick-client application. As operações assíncronas também pode aumentar a taxa de transferência em um aplicativo Web, em que o thread pode ser liberado para atender a outras solicitações enquanto a operação do banco de dados é concluída.Asynchronous operations can also increase throughput in a web application, where the thread can be freed up to service other requests while the database operation completes. Para saber mais, veja Programação assíncrona em C#.For more information, see Asynchronous Programming in C#.

Aviso

O EF Core não oferece suporte para várias operações simultâneas sendo executadas na mesma instância de contexto.EF Core does not support multiple parallel operations being run on the same context instance. Aguarde sempre a conclusão de uma operação antes de iniciar a operação seguinte.You should always wait for an operation to complete before beginning the next operation. Isso geralmente é feito usando a palavra-chave await em cada operação assíncrona.This is typically done by using the await keyword on each asynchronous operation.

O Entity Framework Core fornece DbContext.SaveChangesAsync() como uma alternativa assíncrona para DbContext.SaveChanges().Entity Framework Core provides DbContext.SaveChangesAsync() as an asynchronous alternative to DbContext.SaveChanges().

public static async Task AddBlogAsync(string url)
{
    using (var context = new BloggingContext())
    {
        var blog = new Blog { Url = url };
        context.Blogs.Add(blog);
        await context.SaveChangesAsync();
    }
}