我使用 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 信息,指向另一个数据库。但这正是我卡住的地方。