簡體   English   中英

在ASP.NET MVC EF Database First應用程序中在運行時更改數據源

[英]Change data source at runtime in ASP.NET MVC EF Database First app

我正在嘗試設置我的web.config的connectionString,以便可以在運行時使用下拉列表將其從“data source = MyDevDatabase”更改為“data source = MyQADatabase”。 該應用程序是在ASP.NET MVC中構建的,我使用的是Entity Framework Database First方法,因此我的Models文件夾中有一個.edmx文件。

是我找到的最接近的答案( 使用app.config / web.config文件中的連接字符串向下滾動到Database / Model First )。

但我不知道如何實現它。 有人能舉個例子嗎?

在web.config中有2個不同的連接字符串,有2個名稱。 每次調用數據庫時都必須手動提供連接字符串。

帶有2個連接字符串的Webconfig:

<configuration>
  <connectionStrings>
    <add name="ConnectionString1"
         connectionString="Data Source=.\SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|YourDatabaseFilename1.mdf;User Instance=True"
         providerName="System.Data.SqlClient" />
    <add name="ConnectionString2"
         connectionString="Data Source=.\SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|YourDatabaseFilename2.mdf;User Instance=True"
         providerName="System.Data.SqlClient" />
  </connectionStrings>
</configuration>

這是你如何提供連接字符串:

public MyEntities (string connectionString)
    : base(connectionString)
{
}

看到:

如何在Entity Framework中為不同的用戶提供不同的連接字符串

動態連接字符串的設置實體框架

EntityFramework - 連接字符串在哪里?

您可以使用web.config轉換(XML轉換)來實現。 基本上,您將擁有一個具有不同連接字符串的web.config發布文件,當您在發布模式下構建時,它將使用該轉換來創建最終的web.config。 請在此處查看Microsoft教程。

您可以通過右鍵單擊web.config文件並單擊“添加配置轉換”來添加轉換。

編輯:一旦部署,看起來就像你的意思。 看到這個答案

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM