red*_*man 6 c# nhibernate fluent-nhibernate
如何在没有外键和列名不同的旧数据库上创建HasMany关系?我知道如何使用References在HeaderVersion上创建一对一关系,但不知道如何从Header 1创建HasMany到*HeaderVersion.加入条件应该是:
Header.Id1 = HeaderVersion.PId1 AND Header.Id2 = HeaderVersion.PId2
Run Code Online (Sandbox Code Playgroud)
型号http://i41.tinypic.com/30xbfo5.png
域:
public class Header {
public virtual int Id1 { get; set; }
public virtual int Id2 { get; set; }
public virtual string Something { get; set; }
}
public class HeaderVersion {
public virtual int PId1 { get; set; }
public virtual int PId2 { get; set; }
public virtual int Version { get; set; }
public virtual string SomethingFoo { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
地图:
public HeaderMap() {
Table("Header");
LazyLoad();
CompositeId().KeyProperty(x => x.Id1, "Id1")
.KeyProperty(x => x.Id2, "Id2");
Map(x => x.Something).Column("Something");
}
public HeaderVersionMap() {
Table("HeaderVersion");
LazyLoad();
CompositeId().KeyProperty(x => x.PId1, "PId1")
.KeyProperty(x => x.PId2, "PId2")
.KeyProperty(x => x.Version, "Version");
Map(x => x.SomethingFoo).Column("SomethingFoo");
}
Run Code Online (Sandbox Code Playgroud)
假设Header是(省略了GetHashCode和的覆盖Equals)
public class Header
{
public virtual int Id1 { get; set; }
public virtual int Id2 { get; set; }
public virtual string Something { get; set; }
public virtual ICollection<HeaderVersion> Versions { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
HeaderMap 应该看起来像:
public class HeaderMap : ClassMap<Header>
{
public HeaderMap()
{
Table("Header");
LazyLoad();
CompositeId().KeyProperty(x => x.Id1, "Id1")
.KeyProperty(x => x.Id2, "Id2");
Map(x => x.Something).Column("Something");
HasMany(x => x.Versions).AsBag().KeyColumns.Add("PId1", "PId2");
// Fetch, Inverse, Cascade depend on your mapping strategy
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5225 次 |
| 最近记录: |