Projek API Web anda membolehkan pengguna memilih pangkalan data yang berbeza semasa log masuk. Ini melibatkan pengemaskinian rentetan sambungan Rangka Kerja Entiti secara dinamik. Begini cara untuk mencapainya:
Tukar sambungan
Untuk menukar sambungan konteks data, anda boleh mengubah suai rentetan sambungan SqlConnection yang mendasari. Kelas SqlConnectionStringBuilder menyediakan cara yang mudah untuk membina rentetan sambungan.
<code class="language-csharp">public void Connect(Database database) { // 构建 SQL 连接字符串 SqlConnectionStringBuilder sqlString = new SqlConnectionStringBuilder() { DataSource = database.Server, InitialCatalog = database.Catalog, UserID = database.Username, Password = database.Password, }; // 构建 Entity Framework 连接字符串 EntityConnectionStringBuilder entityString = new EntityConnectionStringBuilder() { Provider = database.Provider, Metadata = Settings.Default.Metadata, ProviderConnectionString = sqlString.ToString() }; // 更新数据上下文的连接 using (var context = new MyDbContext(entityString.ConnectionString)) { // 执行数据库操作 } }</code>
Kegigihan sambungan
Dalam projek API Web, sambungan tidak seharusnya berterusan merentasi keseluruhan sesi pengguna. Setiap permintaan harus menghantar rentetan sambungannya sendiri kepada konteks data. Ini memastikan keselamatan dan menghalang kemungkinan konflik pangkalan data. Anda boleh menyimpan rentetan sambungan dalam sesi atau menghantarnya sebagai parameter kepada panggilan API.
Kaedah sambungan
Pendekatan lain ialah menggunakan kaedah sambungan yang secara automatik melaksanakan operasi gabungan. Kod berikut menunjukkan cara untuk mencapai ini:
<code class="language-csharp">public static class ConnectionTools { public static void ChangeDatabase(this DbContext source, string initialCatalog, string dataSource, ...) { try { var sqlCnxStringBuilder = new SqlConnectionStringBuilder(source.Database.Connection.ConnectionString); if (!string.IsNullOrEmpty(initialCatalog)) sqlCnxStringBuilder.InitialCatalog = initialCatalog; // 更新连接字符串参数 source.Database.Connection.ConnectionString = sqlCnxStringBuilder.ConnectionString; } catch (Exception ex) { /* 记录或处理异常 */ } } }</code>
Anda kemudian boleh menukar sambungan dengan mudah menggunakan kaedah sambungan ini:
<code class="language-csharp">var selectedDb = new MyDbContext(); selectedDb.ChangeDatabase(initialCatalog: "new-catalog");</code>
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengubah Rentetan Sambungan Rangka Kerja Entiti secara Dinamik dalam API Web?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!