0

一些快速的问题:

所以我有这个LogInWindow对话框,用于收集所有 SQL 登录信息,然后将构造的连接字符串传递给ServiceManager.InitializeContext()方法,该方法使用特定的提供程序连接初始化我的实体上下文。

一切正常。但我想LogInWindow用 App.config 配置文件中定义的值初始化对话框。

是否有进行此初始设置的首选方法?即,我是否应该EntityContext仅出于获取默认提供程序连接的纯粹目的而使用默认构造函数来实例化一个虚拟对象?有没有“更清洁”的方式?

顺便说一句,您认为在事件Form.Close()处理程序中执行这种类型的调用是一种“安全”的做法吗?Form.Shown我在 MSDN 上读到,不建议Form.Close()在处理程序内部调用Form.Load事件。

public partial class MainWindow : Form {

    private void MainWindow_Shown(object sender, EventArgs e) {
        using (var logInWindow = new LogInWindow()) {
            if (logInWindow.ShowDialog(this) == DialogResult.OK) {
                this.serviceManager.InitializeContext(logInWindow.ConnectionString);
            } else {
                this.Close();
            }
        }
    }
}


public sealed class ServiceManager : IDisposable {

    public void InitializeContext(string connectionString) {
        if (this.EntityContext != null)
            throw new InvalidOperationException("EntityContext cannot be initialized multiple times.");

        var entityConnectionString = new EntityConnectionStringBuilder();
        entityConnectionString.ProviderConnectionString = connectionString;
        entityConnectionString.Provider = "System.Data.SqlClient";
        entityConnectionString.Metadata = "res://*/EntityModel.EntityModel.csdl|res://*/EntityModel.EntityModel.ssdl|res://*/EntityModel.EntityModel.msl";

        this.EntityContext = new EntityContext(entityConnectionString.ConnectionString);
        this.EntityContext.ObjectMaterialized += EntityContext_ObjectMaterialized;
    }
}
4

1 回答 1

1

您可以使用 System.Configuration 类访问 App.config 的所有部分

例子:

var connectString = ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString;

var stringBuilder = new SqlConnectionStringBuilder(connectString);

string UserID = stringBuilder.UserID;
string Password = stringBuilder.Password;
string catalog = stringBuilder.InitialCatalog;

应用程序配置

<configuration>
   <connectionStrings>
     <add name="MyConnectionString" connectionString="metadata=res://*/...........
   </connectionStrings>
</configuration>
于 2012-11-29T00:36:15.033 回答