IStartupTask連線資料庫的方法
系統啟動時執行任務:IStartupTask,啟動時執行的任務主要是資料庫的初始化和載入。
IStartupTask呼叫IEfDataProvider進行資料庫的初始化。
IEfDataProvider,SqlCeDataProvider:獲取資料連線工廠,不同型別資料庫,連線工廠不同。
介面IStartupTask的實體類EfStartUpTask的實現如下:
public class EfStartUpTask : IStartupTask { public void Execute() { var settings = EngineContext.Current.Resolve
SqlCeInitializer,CreateCeDatabaseIfNotExists初始化資料庫。
IDbContext,NopObjectContext系統資料庫操作上下文。載入所有資料庫對映類:EntityTypeConfiguration
protected override void OnModelCreating(DbModelBuilder modelBuilder) { //dynamically load all configuration //System.Type configType = typeof(LanguageMap); //any of your configuration classes here //var typesToRegister = Assembly.GetAssembly(configType).GetTypes() var typesToRegister = Assembly.GetExecutingAssembly().GetTypes() .Where(type => !String.IsNullOrEmpty(type.Namespace)) .Where(type => type.BaseType != null && type.BaseType.IsGenericType && type.BaseType.GetGenericTypeDefinition() == typeof(EntityTypeConfiguration<>)); foreach (var type in typesToRegister) { dynamic configurationInstance = Activator.CreateInstance(type); modelBuilder.Configurations.Add(configurationInstance); } //...or do it manually below. For example, //modelBuilder.Configurations.Add(new LanguageMap()); base.OnModelCreating(modelBuilder); }
此方法是繼承自DbContext。並在系統啟動時呼叫,建立資料表與實體的.對應關係。
在型別依賴註冊類Nop.Web.Framework.DependencyRegistrar中實現資料庫工廠的建立、資料庫的載入。如下程式碼:
//data layer var dataSettingsManager = new DataSettingsManager(); var dataProviderSettings = dataSettingsManager.LoadSettings(); builder.Register(c => dataSettingsManager.LoadSettings()).As
介面IEfDataProvider 的實體類SqlServerDataProvider的資料庫初始化方法如下:
///
public override void SetDatabaseInitializer() { //pass some table names to ensure that we have nopCommerce 2.X installed var tablesToValidate = new[] {"Customer", "Discount", "Order", "Product", "ShoppingCartItem"}; //custom commands (stored proedures, indexes) var customCommands = new List
另外,EntityFramework本事是ORM框架,透過資料庫訪問上下文建立與資料庫的連線及實體與資料表的對應廣西。並透過建立IRepository