对 DBContext 使用依赖注入时 using 语句应该如何看?

roo*_*z11 3 c# dependency-injection dbcontext ef-core-3.1

将 DBContext 注入我的存储库时,该using语句应该如何显示?

例如:Startup.cs

services.AddDbContext<VisualDbContext>(options => options.UseSqlServer(Configuration["ConnectionStrings:DefaultConnection"]));

Run Code Online (Sandbox Code Playgroud)

VisualDbContext.cs

public partial class VisualDbContext : DbContext
    {
        public VisualDbContext(DbContextOptions<VisualDbContext> options) : base(options)
        {}

        public DbSet<Template> Template { get; set; }
        public DbSet<Exercise> Exercise { get; set; }
        public DbSet<Symbol> Symbol { get; set; }
    }
Run Code Online (Sandbox Code Playgroud)

存储库

public class TemplateRepository : ITemplateRepository
    {
        private readonly VisualDbContext _dbContext;
        public TemplateRepository(VisualDbContext dbContext)

        {
            _dbContext = dbContext;
        }

        public async Task<List<KeyValuePair<char, string>>> GetTemplateAsync(int templateId)
        {
                using (_dbContext) //this seems wrong...
                {
                   ...
                }
        }
Run Code Online (Sandbox Code Playgroud)

Run Code Online (Sandbox Code Playgroud)

Dav*_*oft 5

在 .NET Core 的 DI 中,DbContext 将注册为Scoped Service,这意味着它的生命周期由 DI 容器控制,您不必担心它。

在 ASP.NET Core 中,Scope 与 Http 请求相关联,因此您将在请求处理过程中将相同的 DbContext 实例注入到所有依赖服务中,并且 DbContext 将在请求结束时被处置。

这既简化了您的代码,因为您可以省略 DbContext 的初始化和using其他必要的块,并且它使您能够轻松地确定跨越服务边界的事务的范围。