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)
在 .NET Core 的 DI 中,DbContext 将注册为Scoped Service,这意味着它的生命周期由 DI 容器控制,您不必担心它。
在 ASP.NET Core 中,Scope 与 Http 请求相关联,因此您将在请求处理过程中将相同的 DbContext 实例注入到所有依赖服务中,并且 DbContext 将在请求结束时被处置。
这既简化了您的代码,因为您可以省略 DbContext 的初始化和using其他必要的块,并且它使您能够轻松地确定跨越服务边界的事务的范围。