使用以下类。
public class Trait
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
}
public class Sheet
{
public virtual int Id { get; set; }
public virtual IDictionary<Trait, int> Influences { get; set; }
}我试着用Fluent nHibernate来映射它们。
public class TraitMap : ClassMap<Trait>
{
public TraitMap()
{
Id(x => x.Id);
Map(x => x.Name);
Table("Traits");
}
}
public class SheetMap : ClassMap<Sheet>
{
public SheetMap()
{
Id(x => x.Id);
HasManyToMany<Trait>(x => x.Influences)
.Schema("Sheets")
.Table("Influences")
.ParentKeyColumn("Trait")
.ChildKeyColumn("Sheet")
.AsMap<int>("Rating")
.Cascade.All();
Table("Sheets");
}
}这不管用。我知道例外了。
Trait.Id的getter异常发生
现在,如果我把字典改成这样..。
public class Sheet
{
public virtual int Id { get; set; }
public virtual IDictionary<int, Trait> Influences { get; set; }
}基本上,让int成为关键,使特性成为值(不是我想要的),它确实有效。有人能解释这一点吗?我怎样才能更恰当地复制我想要做的事情呢?
我认为推理是因为当我指定
HasManyToMany<Trait>时,我指定了集合的值元素。不过,这不是我的本意。
我想根据键的名称,而不是值的名称来查找事物。虽然我意识到这在技术上是一个“可接受的”解决方案,但它有点违背字典惯例。如果可能的话,我更愿意采取更多的约定而不是解决方案--我想更好地理解幕后到底发生了什么。
发布于 2010-10-13 15:29:16
您想要的是hbm中的<composite-index>映射会给您带来什么。我相信不是AsMap,你会想要AsEntityMap。然而,看这条线谈到了重写(8月)的fluent地图映射,这使得所有这些都过时了。
编辑:对于AsEntityMap和其他选项,请查看这个问题 和回答
HasMany<Trait>(x => x.Influences)
.KeyColumn("key column name")
.AsEntityMap("referenced column name")
.Entity("dict value", v=> v.Type<int>());此外,您还说您使用的是最新版本--最新版本为1.1,但主干版本为2.0,非常不同,而且进展得更远。如果您不在2.0+上,您将不会看到大多数帮助线程中发布的方法,比如上面链接的帮助线程。
https://stackoverflow.com/questions/3925112
复制相似问题