依赖注入(Dependency Injection,简称DI)是一种设计模式,用于实现控制反转(IoC),它把对象的创建和使用分离。简单说,就是不直接在类内部创建依赖对象,而是通过外部传入所需依赖,让类更灵活、更容易测试和维护。
为什么在数据库项目中用依赖注入?
在C#数据库项目中,通常会用到Entity Framework Core的DbContext来操作数据库。如果每次都在类里直接new一个DbContext,会导致代码紧耦合,难以替换实现或进行单元测试。通过依赖注入,可以把DbContext注册为服务,由容器统一管理其生命周期,按需注入到需要它的类中。
如何在C#项目中配置依赖注入管理数据库上下文?
以ASP.NET Core项目为例,以下是具体步骤:
1. 安装必要的包:确保已安装 Entity Framework Core 和对应的数据库提供程序,比如 Microsoft.EntityFrameworkCore.SqlServer。 2. 创建 DbContext 类:
public class AppDbContext : DbContext
{
public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }
public DbSet<User> Users { get; set; }
}
3. 在 Program.cs 中注册 DbContext(.NET 6 及以上):
var builder = WebApplication.CreateBuilder(args);
// 添加 DbContext 到服务容器
builder.Services.AddDbContext<AppDbContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
var app = builder.Build();
4. 在控制器或服务中使用:依赖注入会自动把 DbContext 注入进来。
public class UserController : ControllerBase
{
private readonly AppDbContext _context;
public UserController(AppDbContext context)
{
_context = context;
}
public async Task<IActionResult> GetUsers()
{
var users = await _context.Users.ToListAsync();
return Ok(users);
}
}
DbContext 的生命周期管理
Entity Framework Core 推荐将 DbContext 设置为作用域生命周期(Scoped),这意味着每个HTTP请求会使用同一个实例,避免资源冲突和性能问题。AddDbContext 默认就是 Scoped,无需额外配置。
如果在后台服务或多线程场景中使用,要注意不要跨线程共享实例,应使用 IServiceScope 创建独立作用域来获取新的上下文实例。
基本上就这些。依赖注入让数据库上下文的管理更清晰,解耦了数据访问逻辑,也方便做Mock测试。只要正确配置生命周期,就能安全高效地在项目中使用。
