NopCommerce架构分析之三---数据库初试化及数据操作
时间:2021-07-01 10:21:17
帮助过:3人阅读
- public class EfStartUpTask : IStartupTask
- {
- public void Execute()
- {
- var settings = EngineContext.Current.Resolve<DataSettings>();
- if (settings != null && settings.IsValid())
- {
- var provider = EngineContext.Current.Resolve<IEfDataProvider>();
- if (provider == null)
- throw new NopException("No EfDataProvider found");
- provider.SetDatabaseInitializer();
- }
- }
-
- public int Order
- {
-
- get { return -1000; }
- }
- }
SqlCeInitializer,CreateCeDatabaseIfNotExists初始化数据库。
IDbContext,NopObjectContext系统数据库操作上下文。加载所有数据库映射类:EntityTypeConfiguration<TEntityType>。代码如下:
[csharp] view plain
copy
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
-
-
-
-
- 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);
- }
-
-
-
-
-
- base.OnModelCreating(modelBuilder);
- }
此方法是继承自DbContext。并在系统启动时调用,建立数据表与实体的对应关系。
在类型依赖注册类Nop.Web.Framework.DependencyRegistrar中实现数据库工厂的创建、数据库的加载。如下代码:
[html] view plain
copy
- //data layer
- var dataSettingsManager = new DataSettingsManager();
- var dataProviderSettings = dataSettingsManager.LoadSettings();
- builder.Register(c => dataSettingsManager.LoadSettings()).As<DataSettings>();
- builder.Register(x => new EfDataProviderManager(x.Resolve<DataSettings>())).As<BaseDataProviderManager>().InstancePerDependency();
-
-
- builder.Register(x => (IEfDataProvider)x.Resolve<BaseDataProviderManager>().LoadDataProvider()).As<IDataProvider>().InstancePerDependency();
- builder.Register(x => (IEfDataProvider)x.Resolve<BaseDataProviderManager>().LoadDataProvider()).As<IEfDataProvider>().InstancePerDependency();
-
- if (dataProviderSettings != null && dataProviderSettings.IsValid())
- {
- var efDataProviderManager = new EfDataProviderManager(dataSettingsManager.LoadSettings());
- var dataProvider = (IEfDataProvider)efDataProviderManager.LoadDataProvider();
- dataProvider.InitConnectionFactory();
-
- builder.Register<IDbContext>(c => new NopObjectContext(dataProviderSettings.DataConnectionString)).InstancePerHttpRequest();
- }
- else
- {
- builder.Register<IDbContext>(c => new NopObjectContext(dataSettingsManager.LoadSettings().DataConnectionString)).InstancePerHttpRequest();
- }
-
-
- builder.RegisterGeneric(typeof(EfRepository<>)).As(typeof(IRepository<>)).InstancePerHttpRequest();
接口IEfDataProvider 的实体类SqlServerDataProvider的数据库初始化方法如下:
[csharp] view plain
copy
-
-
- public override void SetDatabaseInitializer()
- {
-
- var tablesToValidate = new[] {"Customer", "Discount", "Order", "Product", "ShoppingCartItem"};
-
-
-
- var customCommands = new List<string>();
-
- customCommands.AddRange(ParseCommands(HostingEnvironment.MapPath("~/App_Data/SqlServer.Indexes.sql"), false));
-
- customCommands.AddRange(ParseCommands(HostingEnvironment.MapPath("~/App_Data/SqlServer.StoredProcedures.sql"), false));
-
- var initializer = new CreateTablesIfNotExist<NopObjectContext>(tablesToValidate, customCommands.ToArray());
- Database.SetInitializer(initializer);
- }
另外,EntityFramework本事是ORM框架,通过数据库访问上下文建立与数据库的连接及实体与数据表的对应广西。并通过创建IRepository<T>的泛型实体类来实现对每一种数据的处理,也就是所谓的Dao层。业务逻辑层通过每种实体的数据访问仓库Repository<T>来进行数据库操作。如下图:
NopCommerce架构分析之三---数据库初试化及数据操作
标签: