加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – 多个DbContext,多个Database.SetInitializer

发布时间:2020-12-16 00:12:53 所属栏目:asp.Net 来源:网络整理
导读:我创建了两个DbContexts,一个用于应用程序配置,第二个用于日志记录. 原因是,我想在日志记录数据库上设置最大大小,这样就不会耗尽所有可用磁盘空间并阻止其他数据库工作. 在我的global.asax.cs文件中,我有以下内容: protected void Application_Start() { Ar
我创建了两个DbContexts,一个用于应用程序配置,第二个用于日志记录.

原因是,我想在日志记录数据库上设置最大大小,这样就不会耗尽所有可用磁盘空间并阻止其他数据库工作.

在我的global.asax.cs文件中,我有以下内容:

protected void Application_Start()
    {

        AreaRegistration.RegisterAllAreas();

        RegisterGlobalFilters(GlobalFilters.Filters);
        RegisterRoutes(RouteTable.Routes);

        Database.SetInitializer<AdminContext>(new AdminInitialiser());
        Database.SetInitializer<LoggingContext>(new LoggingInitialiser());
    }

未调用LoggingInitialiser中的InitializeDatabase方法.这是因为只能设置一个初始值设定项吗?有没有办法让两个DbContexts的初始化器?

解决方法

而是在DbContext构造函数中设置初始化程序.
public class AdminContext : DbContext
{
    public AdminContext()
    {
        Database.SetInitializer(new AdminInitialiser());
    }
}

public class LoggingContext : DbContext
{
    public LoggingContext()
    {
        Database.SetInitializer(new LoggingInitialiser());
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读