gpt4 book ai didi

asp.net-core - 数据库中已经有一个名为 AspNetRoles 的对象。 ( Entity Framework 核心)

转载 作者:行者123 更新时间:2023-12-04 15:51:57 28 4
gpt4 key购买 nike

我有一个使用 Entity Framework 核心的 asp.net 核心 mvc 网站。

我不知道它最初是如何发生的,但我无法克服错误:
“数据库中已经有一个名为 AspNetRoles 的对象”

我最终删除了数据库,删除了所有迁移 .cs 文件并从头开始。

然后我试过了add-migration MyInitialMigration
同样的错误

然后我再次删除了数据库,并尝试了直接update-database(不添加迁移)

还是同样的错误

我尝试更改 appsettings 配置字符串以指向一个新的、不存在的数据库。

还是一样的错误!

以前在 MVC5/EF6 上我遇到过这个错误,并使用与这个答案相同的方法解决了它:
There is already an object named in the database
-Add-Migration Initial -IgnoreChanges
但是 -IgnoreChanges 在 EFCore 中不受支持

或者之前在 EF6 上,我通过添加迁移来解决它,然后删除 Up/Down 中的所有内容并运行空迁移。这在 EFCore 上不起作用

我怎样才能继续?我检查了迁移表,即使每次都创建了整个数据库,它们始终是空的。只是似乎没有将它记录在迁移表中

最佳答案

发现我的问题。

我按照本教程从 EntityFramework 加载 appsettings:
https://docs.asp.net/en/latest/fundamentals/configuration.html#example-entity-framework-settings

在 EntityFrameworkConfigurationProvider 中有一个 public override void Load()其中有一个 dbContext.Database.EnsureCreated();和一个 CreateAndSaveDefaultValues
在这两者之间,它看起来像是在没有跟踪迁移的情况下初始化数据库。

我将这些注释掉,进行了迁移,并且运行良好。希望每次我想运行迁移时都不必将它们注释掉:/

关于asp.net-core - 数据库中已经有一个名为 AspNetRoles 的对象。 ( Entity Framework 核心),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39609551/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com