gpt4 book ai didi

c# - .NET Entity Framework : Add-Migration is too slow

转载 作者:行者123 更新时间:2023-11-30 17:01:59 25 4
gpt4 key购买 nike

我正在努力将 Entity Framework 添加到我们当前基于 Web 的项目中。我们的项目目前有 572 个表。我也在考虑将我们的数据库处理切换为使用迁移,而不是我们现在的处理方式(这是一个臃肿的 sql 文件,在我们进行合并时最终会变得很麻烦)。我创建了一个测试项目来试用 Entity Framework 。能够对模型进行逆向工程(这需要一些时间,但肯定值得花时间)。下一步,我运行了启用迁移,创建了第一个迁移(在 up 方法中有每个表),这没什么大不了的。我遇到的问题是,当我向模型添加一个属性,然后运行“添加迁移”时,它花费的时间太长了。它已经运行了大约 40 分钟,而我所做的只是创建一个专栏……它仍然没有完成。有关如何加快此过程的任何想法。或者甚至是一种手动创建这些迁移的方法(截至目前,我可能更容易输入 AddColumn 和 DropColumn,而不是 EF 自动执行)。请帮忙,我想把这个作为一个可行的选择呈现给我的老板。

最佳答案

我猜你已经在一个与你的入口点(即你的网络应用程序、控制台应用程序等)分开的程序集中定义了你的模型。

在您的数据程序集中创建一个新的 app.config 并至少定义以下内容:

<configuration>
<connectionStrings>
<add name="MyDB" connectionString="Data Source=localhost; Initial Catalog=MyDB; Integrated Security=SSPI; MultipleActiveResultSets=True;" providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>

调用add-migration或update-database时有时也需要定义连接字符串名:

Update-Database -ConnectionStringName MyDB
Add-Migration MyMigration -ConnectionStringName MyDB

虽然我无法弄清楚需要这个的配置有什么不同。

当 EF 无法联系您的数据库以尝试从中获取一些信息时,似乎会出现添加迁移速度缓慢的情况,因此它会等待超时,然后再回退到它已经知道的关于您的数据库的信息。您可能会发现在这种情况下您也无法调用 Update-Database - 这就是原因。

关于c# - .NET Entity Framework : Add-Migration is too slow,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20462856/

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