在Entity Framework中动态选择数据库

时间:2013-05-25 17:55:20

标签: c# sql entity-framework entity-framework-4

我有多个具有相同模式的SQL数据库.Say(Database1,Database2 ....)

如何在运行时动态选择Entity框架模型中的数据库?。由于它们具有相同的模式,因此导入所有数据模型没有意义。

1 个答案:

答案 0 :(得分:3)

您可以像这样更改数据库连接字符串:

DataModelContainer context = new DataModelContainer(
                    ConnectionOperation.CreateEntityConnection());

这是CreateEntityConnection方法:

internal static EntityConnection CreateEntityConnection()
            {
                // Start out by creating the SQL Server connection string
                SqlConnectionStringBuilder sqlBuilder = new SqlConnectionStringBuilder();

                // Set the properties for the data source. The IP address network address
                sqlBuilder.DataSource = System.Configuration.ConfigurationManager.AppSettings["Connection"];
                // The name of the database on the server
                sqlBuilder.UserID = "sa";
                sqlBuilder.Password = "12345";
                sqlBuilder.InitialCatalog = "DatabaseName";
                sqlBuilder.IntegratedSecurity = true;
                sqlBuilder.MultipleActiveResultSets = true;
                // Now create the Entity Framework connection string
                EntityConnectionStringBuilder entityBuilder = new EntityConnectionStringBuilder();
                //Set the provider name.
                entityBuilder.Provider = "System.Data.SqlClient";
                // Set the provider-specific connection string.
                entityBuilder.ProviderConnectionString = sqlBuilder.ToString();

                // Set the Metadata location. 
                entityBuilder.Metadata = @"res://*/DataModel.csdl|res://*/DataModel.ssdl|res://*/DataModel.msl";

                // Create and entity connection
                EntityConnection conn = new EntityConnection(entityBuilder.ToString());
                return conn;
            }