数据库的初始化与控制

来源:互联网 发布:内存优化表的缺点 编辑:程序博客网 时间:2024/05/19 12:28

初始化包括两个主要步骤。首先,使用Code First在内存中根据默认规则和配置创建模型。其次,使用已设置的数据库初始化器将用于存储数据的数据库初始化。

初始化是延迟加载的,所以创建一个实例的是不完全满足初始化发生的条件的。必须执行对模型的操作,如查询或添加实体才会发生。

但我们可以可以调用DbContext.Database.Initialize方法,在没有对模型执行任何操作的时候强制初始化。

有三个方法可以控制数据库初始化时的行为。

1 CreateDatabaseIfNotExists

CreateDatabaseIfNotExists方法会在没有数据库时创建一个,这是默认行为。

                Database.SetInitializer(
                    new CreateDatabaseIfNotExists<BreakAwayContext>());
                using (var context = new BreakAwayContext())
                {
                    context.Database.Initialize(true);
                }
2 DropCreateDatabaseIfModelChanges

如果我们在在模型改变时,自动重新创建一个新的数据库,就可以用这个方法。在这开发过程中非常有用。

                Database.SetInitializer(
                    new DropCreateDatabaseIfModelChanges<BreakAwayContext>());
                using (var context = new BreakAwayContext())
                {
                    context.Database.Initialize(true);
                }
3 DropCreateDatabaseAlways

如果你想在每次运行时都重新生成数据库就可以用这个方法。

                Database.SetInitializer(
                    new DropCreateDatabaseAlways<BreakAwayContext>());
                using (var context = new BreakAwayContext())
                {
                    context.Database.Initialize(true);
                }

原创粉丝点击