如何在nhibernate中同时连接多个数据库

 我来答
匿名用户
推荐于2016-01-30
展开全部
public interface ISessionFactoryHolder
{
ISessionFactory GetSessionFactoryForEntity<TEntity>() where TEntity : IEntity;
}

public class SessionFactoryHolder : ISessionFactoryHolder
{
private IDictionary<string, int> entityDictionary;
private IDictionary<int, ISessionFactory> factoryDictionary;

public SessionFactoryHolder()
{
this.entityDictionary = new Dictionary<string, int>();
this.factoryDictionary = new Dictionary<int, ISessionFactory>();
}

#region ISessionFactoryHolder Members

public ISessionFactory GetSessionFactoryForEntity<TEntity>() where TEntity : IEntity
{
int hashCode = 0;

Asserts.Assert<MappingException>(
this.EntityInDictionary(typeof(TEntity).FullName, out hashCode) == false
, string.Format("No persister for:{0}", typeof(TEntity).FullName));

return this.factoryDictionary[hashCode];
}

#endregion

public void RegisterSessionFactory(ISessionFactory sessionFactory)
{
Asserts.IsNotNull(sessionFactory, "sessionFactory");

this.factoryDictionary[sessionFactory.GetHashCode()] = sessionFactory;

this.MapingEntityNameToSessionFactoryHashCode(sessionFactory.Statistics.EntityNames
, sessionFactory.GetHashCode());
}

private bool EntityInDictionary(string entityName, out int sessionFactoryHashCode)
{
return this.entityDictionary.TryGetValue(entityName, out sessionFactoryHashCode);
}

private void MapingEntityNameToSessionFactoryHashCode(string[] entityNames, int sessionFactoryHashCode)
{
foreach (var entityName in entityNames)
{
this.entityDictionary[entityName] = sessionFactoryHashCode;
}
}
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式