gpt4 book ai didi

entity-framework - 如何处理 EF 4.1 运行时的动态连接字符串?

转载 作者:行者123 更新时间:2023-12-03 23:38:27 25 4
gpt4 key购买 nike

我不能使用配置文件,我必须在运行时初始化数据库连接。它是 SQL Server 2008 数据库。

自从我将 EF 更新到更新的 ADO.NET Entity Framework 4.1 - Update 1 后,Database.Connection.ConnectionString 不再对我起作用。配置文件中的连接字符串对我来说工作正常,但我需要动态定义它。所以我通过 DefaultConnectionFactory 找到了其他流行的方式来做到这一点:

Database.DefaultConnectionFactory = 
new SqlConnectionFactory("Server=local;Initial Catalog=Db1;Trusted_Connection=True;")

但是在这种情况下,我在尝试访问任何 DbSet 派生对象时收到错误消息:提供程序未返回 ProviderManifestToken 字符串。 ---> System.Data.SqlClient.SqlException:建立与 SQL Server 的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称是否正确以及 SQL Server 是否配置为允许远程连接。 (提供程序:命名管道提供程序,错误:40 - 无法打开与 SQL Server 的连接)

更新:只有在数据库尚未创建且应该由 EF 重建的情况下,我才会遇到此问题。如果它存在,则在我查询 Db 数据时不会发生此类异常。如果我在配置文件中定义完全相同的连接字符串,这两种情况对我来说都很好(数据库生成和数据查询)

我做错了什么?谢谢

最佳答案

您可以使用 EntityConnectionStringBuilder 类为上下文构建连接字符串,

EntityConnectionStringBuilder entityBuilder =new EntityConnectionStringBuilder();
entityBuilder.Provider = "provider";
entityBuilder.ProviderConnectionString = "connectionString";

并在创建 dbContext 时通过

 YourContext(entityBuilder.ToString())

关于entity-framework - 如何处理 EF 4.1 运行时的动态连接字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6920405/

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