首先通过依赖注入在Program.cs中注册DbContext并配置连接字符串,接着在appsettings.json中定义连接信息,然后创建继承DbContext的类并注入到控制器使用,最后可选配置如日志、超时等选项以增强功能。

在C#中配置数据库上下文(如Entity Framework Core的DbContext)时,通常通过依赖注入(Dependency Injection, DI)来管理其生命周期和配置。这是ASP.NET Core应用中的标准做法。
1. 创建DbContext类
首先定义一个继承自DbContext的类:
public class AppDbContext : DbContext{
public AppDbContext(DbContextOptions<AppDbContext> options) : base(options) { }
public DbSet<User> Users { get; set; }
// 其他DbSet...
}
2. 在Program.cs或Startup.cs中配置依赖注入
在现代ASP.NET Core项目(.NET 6+)中,使用Program.cs进行服务注册:
var builder = WebApplication.CreateBuilder(args);// 添加DbContext并配置连接字符串
builder.Services.AddDbContext<AppDbContext>(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<IEnumerable<User>> Get() => await _context.Users.ToListAsync();
}
5. 配置上下文选项的常见方式
除了UseSqlServer,还可以根据需要配置其他行为:
- 启用敏感数据日志:options.EnableSensitiveDataLogging()
- 设置命令超时:options.CommandTimeout(30)
- 使用内存数据库(测试用):options.UseInMemoryDatabase("TestDb")
- 启用详细错误信息:options.EnableDetailedErrors()
示例:
builder.Services.AddDbContext<AppDbContext>(options =>{
options.UseSqlServer(connectionString);
options.EnableSensitiveDataLogging();
options.EnableDetailedErrors();
}); 基本上就这些。通过依赖注入配置DbContext,既符合设计原则,也便于测试和维护。










