我有三个SQL Server数据库,单个应用程序从中检索数据。我正在使用NHibernate从不同的数据库中检索数据。我设置了一些东西,以便每个数据库在自己的程序集中都有自己的存储库和类映射。在我的castle.config文件中,我使用Castle NHibernate工具设置了数据库连接:
<?xml version="1.0" encoding="utf-8" ?>
<castle>
<facilities>
<facility id="factorysupport" type="Castle.Facilities.FactorySupport.FactorySupportFacility, Castle.Windsor" />
<facility id="nhibernate" isWeb="false" type="Castle.Facilities.NHibernateIntegration.NHibernateFacility, Castle.Facilities.NHibernateIntegration">
<factory id="databaseone.factory" alias="databaseone">
<settings>
<!--Settings Here -->
</settings>
<assemblies>
<assembly>DAL.DatabaseOne</assembly>
</assemblies>
</factory>
<factory id="databasetwo.factory" alias="databasetwo">
<settings>
<!--Settings Here -->
</settings>
<assemblies>
<assembly>DAL.DatabaseTwo</assembly>
</assemblies>
</factory>
<factory id="databasethree.factory" alias="databasethree">
<settings>
<!--Settings Here -->
</settings>
<assemblies>
<assembly>DAL.DatabaseThree</assembly>
</assemblies>
</factory>
</facility>
</facilities>
</castle>
我的所有存储库都有一个构造函数,它以ISessionFactory作为参数:
public MyRepository<T> : IRepository<T>
{
public MyRepository(ISessionFactory factory)
{
//Do stuff here
}
}
我有一个安装程序类,我想在其中定义各种存储库:
//In install method of IWindsorInstaller
container.register(Component.For(typeof(IRepository<>)).ImplementedBy(typeof(MyRepository<>));
使用一个数据库可以正常工作。当我将第二个数据库添加到混合中时,相同的ISessionFactory将注入到所有存储库中。我的问题是处理这个问题的最佳方法是什么?我可以手动指定哪个ISessionFactory应该注入哪个Repository&lt;&gt;但我似乎无法找到这方面的文件。最好的方法是,如果我可以这样说:对于程序集DAL.DatabaseOne中的所有类映射,总是注入对应于databaseone.factory的ISessionFactory;对于程序集DAL.DatabaseTwo中的所有类映射,始终注入与databasetwo.factory对应的ISessionFactory。
想法或建议?
答案 0 :(得分:0)
在this post by Fabio Maulo中,在“为多个数据库配置DAO /存储库”标题下进行了解释。
他为每个域类单独映射工厂,但您也可以在案例中的每个域程序集上使用反射来注册相应的工厂。