我正在建立我的第一个.NET 6 MVC站点,并陷入了第一个障碍。
我在解决方案中有3个项目。域:包含实体基础设施:有应用程序DB上下文WebUi:包含web接口
添加迁移和更新数据库可以很好地工作,但是当我尝试搭建控制器时,它会出现以下错误:
运行所选代码生成器时出现错误:在试图激活'Microsoft.EntityFrameworkCore.DbContextOptions’时无法解析
类型的服务
然后在其他类库项目中命名DbContext。
几个月前,我发现其他人也有过类似的问题,但是没有人有其他的解决办法,然后把所有的东西都纳入到同一个项目中。
有人遇到这种情况并找到了解决办法吗?
发布于 2022-03-04 07:12:14
最后,找到了一些对我有用的东西:您可以使用ApplicationDbContext类在同一个文件夹中创建dbcontext工厂类。此工厂类在设计时创建ApplicationDbContext,脚手架正确运行。
public class ApplicationDbContextFactory : IDesignTimeDbContextFactory<ApplicationDbContext>
{
public ApplicationDbContext CreateDbContext(string[] args)
{
var optionsBuilder = new DbContextOptionsBuilder<ApplicationDbContext>();
optionsBuilder.UseSqlServer("Server=(localdb)\\MSSQLLocalDB;Database=EcommerceDb;Trusted_Connection=True;MultipleActiveResultSets=true");
return new ApplicationDbContext(optionsBuilder.Options);
}
}信用额度为:https://github.com/dotnet/Scaffolding/issues/1765#issuecomment-1058674843
发布于 2022-02-23 22:43:37
首先,确保在与上下文相同的项目中有正确的包。你需要以下几点。
microsoft.aspnetcore.diagnostics.entityframeworkcore
microsoft.entityframeworkcore.sqlserver
还要确保在上下文中使用硬编码的选项生成器连接,而不是像下面这样的name参数。只需记住在发布更改之前将其更改回。
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
if (!optionsBuilder.IsConfigured)
{
//optionsBuilder.UseSqlServer
//("Name=ConnectionStrings:[AppSettingsConnectionName]");
// Use this OB to scaffold
optionsBuilder.UseSqlServer
(@"Data Source=[Server];Initial Catalog=[DBName];");
}
}https://stackoverflow.com/questions/71196547
复制相似问题