gpt4 book ai didi

c# - 从 web.config 获取连接字符串以在 EF POCO 中使用?

转载 作者:太空宇宙 更新时间:2023-11-03 13:51:18 27 4
gpt4 key购买 nike

我注意到,当我使用 EF 创建模型优先的数据库时,它会忽略 web.config 连接字符串并在后台执行它自己的操作。然后我找到了一种在构造函数中设置自己的连接字符串的方法。

public class MainDataContext : DbContext
{
public MainDataContext()
{
this.Database.Connection.ConnectionString = "MY CONNECTION STRING THAT IS ACTUALLY USED";
}
}

问题:如何强制/设置它使用来自 web.config 的连接字符串?

有人告诉我,如果您像命名数据上下文一样命名您的连接字符串,它会起作用,但它不适合我。我很确定,如果我将它命名为 DefaultConnectionString,它是行不通的。

<add name="MainDataContext" providerName="System.Data.SqlClient"
connectionString="Server=(LocalDB)\\v11.0;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|ProjectDB.mdf;" />

当我尝试从控制台执行 update-database -v -f 时发生错误。

最佳答案

你可以尝试这样的事情:

public MainDataContext() :
base(typeof(MainDataContext).Name)
{
}

您确定您在 Web.config 中的连接字符串声明是正确的吗?像这样:

<?xml version="1.0"?>
<configuration>
<connectionStrings>
<add name="MyDatabase" connectionString="server=localhost;User Id=user;password=password;Persist Security Info=True;database=mydatabase" providerName="MySql.Data.MySqlClient" />
</connectionStrings>
</configuration>

关于c# - 从 web.config 获取连接字符串以在 EF POCO 中使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13609332/

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