我有一个简单的架构,如下所示:
这个想法是有用户,部门和流程。对于每个部门,用户可以“标记”多个流程以“标记”它们(因此部门/用户对可以有许多流程)。
理想情况下,我想使用以下类:
public class User
{
public virtual int Id { get; protected set; }
public virtual string Name { get; set; }
}
public class Department
{
public virtual int Id { get; protected set; }
public virtual string Name { get; set; }
public virtual IDictionary<User, IList<StarredFlow>> StarredFlows { get; protected set; }
public Department()
{
this.UserStarredFlows = new Dictionary<User, IList<StarredFlow>>();
}
}
public class Flow
{
public virtual int Id { get; protected set; }
public virtual string Name { get; set; }
protected Flow() { }
}
public class StarredFlow
{
public virtual int Id { get; protected set; }
public virtual User User { get; protected set; }
public virtual Department EntryPoint { get; protected set; }
public virtual Flow Flow { get; protected set; }
public virtual string Name { get; protected set; }
protected StarredFlow() { }
public StarredFlow(User user, Department ep, Flow flow, string name)
{
this.User = user;
this.EntryPoint = ep;
this.Flow = flow;
this.Name = name;
}
}
这个将允许相当文字的代码:
var userStarredFlowsForDepartment = department.StarredFlows[currentUser];
但是,NHibernate不支持映射列表的字典。我找到了similar question/answer,其中涉及将IList<StarredFlow>
移动到新类并使用组件映射它。遗憾的是,FluentNHibernate不支持使用组件进行集合映射(组件映射没有HasMany
)。
对于NHibernate来说,这似乎是一件微不足道的事情,但我很难找到解决方案。这样做有更好的解决方案吗?我真的希望不必须使用session.Save(starredFlow)
和Query<StarredFlow>()
来解析只是,因为它们会将逻辑移到模型之外。
答案 0 :(得分:0)
您想要做的是绝对不受支持。我并不是说它不是一个理论上有效的设计,但是NHibernate不支持它,它不太可能在将来这样做。
也就是说,你可以在Department
而不是字典中使用IQueryable
来获取方法:
public IEnumerable<StarredFlow> GetUserStarredFlows(IQueryable<StarredFlow> source,
User user)
{
return source.Where(x => x.User == user)
.ToList(); //you could skip this depending on your usage
}
或者(稍微复杂一点)你可以注入IQueryable
或会话。