在C#中配置数据库上下文(如Entity Framework Core的DbContext)时,通常通过依赖注入(Dependency Injection, DI)来管理其生命周期和配置。这是ASP.NET Core应用中的标准做法。
1. 创建DbContext类
首先定义一个继承自DbContext的类:
public class AppDbContext : DbContext{
public AppDbContext(DbContextOptions options) : base(options) { }
public DbSet
// 其他DbSet...
}
2. 在Program.cs或Startup.cs中配置依赖注入
在现代ASP.NET Core项目(.NET 6+)中,使用Program.cs进行服务注册:
var builder = WebApplication.CreateBuilder(args);// 添加DbContext并配置连接字符串
builder.Services.AddDbContext(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection"))
);
var app = builder.Build();
这样就将AppDbContext注册到了DI容器中,并指定了使用SQL Server以及对应的连接字符串。
3. 配置连接字符串
在appsettings.json中添加连接字符串:
{"ConnectionStrings": {
"DefaultConnection": "Server=localhost;Database=MyAppDb;User=sa;Password=your_password;"
}
}
4. 使用DbContext
注册后,可以在控制器或其他服务中通过构造函数注入使用:
public class UsersController : ControllerBase{
private readonly AppDbContext _context;
public UsersController(AppDbContext context)
{
_context = context;
}
[HttpGet]
public async Task
}
5. 配置上下文选项的常见方式
除了UseSqlServer,还可以根据需要配置其他行为:
启用敏感数据日志:options.EnableSensitiveDataLogging() 设置命令超时:options.CommandTimeout(30) 使用内存数据库(测试用):options.UseInMemoryDatabase("TestDb") 启用详细错误信息:options.EnableDetailedErrors()示例:
builder.Services.AddDbContext(options =>{
options.UseSqlServer(connectionString);
options.EnableSensitiveDataLogging();
options.EnableDetailedErrors();
}); 基本上就这些。通过依赖注入配置DbContext,既符合设计原则,也便于测试和维护。
