2

我使用 Fluent NHibernate,现在必须处理存档数据,其中同一个表存在于多个 MSSQL 数据库中。根据用户提供的日期值,我必须连接到不同的数据库,而所有映射信息保持不变。

更具体:如果提供的 Date 值在当前年份内,则使用 DB CUR,否则使用年度 DB(2011、2010、2009、...)。

现在有一段时间人们告诉我一遍又一遍地重新创建一个 SessionFactory 是一件相当昂贵的事情,所以我心想一定有一种方法可以使用现有的 sessionFactory,更新我的 ClassMap(类似于更改架构从“CUR.DBO”到“2011.DBO”)并重新连接。

我尝试将 FluentConfiguration 和 SessionFactory 弄得一团糟,但后来我膝盖中了一箭,找不到在运行时刷新映射的方法。

我最终会创建一个新的 SessionFactory 吗?或者有没有人知道在运行时重新初始化(Fluent)NHibernate 映射的可行程序?

编辑:一个非常重要的细节,SqlConnection 也是外部提供的。它提供对所有数据库的访问,这意味着理论上我永远不必创建连接。所以,基本上我要做的就是为每个 Archive 创建一个 SessionFactory 来更新 Mapping 的 Schema 信息,指向另一个数据库。但这正是我卡住的地方。

4

3 回答 3

1

确实,创建会话工厂是比创建会话更昂贵的操作,因此您当然不想为对数据库的每个查询都创建一个。

但是,根据我的经验,最多只需要几秒钟。

我建议您每次用户选择不同的年份时创建一个新的。如果您在发生这种情况时给他们很好的反馈(可能是一个对话框,上面写着“连接到 2010 数据库”,带有进度条),他们可能不会介意等待。

一旦你创建了一个一年,如果他们在同一年进行更多查询,你可以重复使用它,所以他们每年只需要等待一次被查询。

如果创建会话工厂花费的时间太长,我已经看到了解释如何保存或缓存配置以减少创建时间的帖子。然而,一个快速的谷歌并没有找到任何好的链接,所以你可能需要研究一下,或者问另一个问题。

于 2012-04-13T15:10:29.083 回答
1

感谢您的回复/评论。实际上我还没有找到重用会话工厂的方法,所以我最终按照建议为它们创建了一个查找列表。以下解决方案可以满足我的需要(更改数据库),我们将了解它的执行方式:

    private IDictionary<string, ISessionFactory> _sessionFactories;

    public SqlConnection Connection { get; set; }

    public ISessionFactory GetSessionFactory(string dbName)
    {
        if (_sessionFactories.ContainsKey(dbName))
        {
            return _sessionFactories[dbName];
        }

        FluentConfiguration cfg = Fluently.Configure().Database(MsSqlConfiguration.MsSql2008
                                                                .ShowSql()
                                                                .ConnectionString(c=>c.Is(Connection.ConnectionString)))
                                                      .Mappings(x=>x.FluentMappings.Add<MappedClassMap>());
        cfg.ExposeConfiguration(x => x.GetClassMapping(typeof(MappedClass)).Table.Schema = string.Format("{0}.dbo",dbName));
        ISessionFactory sf = cfg.BuildSessionFactory();
        _sessionFactories.Add(dbName, sf);
        return sf;
    }
于 2012-04-16T07:04:47.073 回答
0

如果为单个数据库创建 sessionfactory 似乎就足够了。但是,在使用 Sessionfactory 实例打开会话时,可以使用重载方法来提供 dbconnection 对象,我们可以在其中切换数据库。已经验证它并且它工作正常。

于 2016-07-20T12:38:48.133 回答