我的数据库看起来像这样:
MyEntity State
----- -----
id id
street name
stateId ...
zip
status
...
我的模型看起来像这样:
class MyEntity
{
int id { get; set; }
Address location { get; set; }
string status { get; set; }
// ...
}
class Address
{
string street { get; set; }
string zip { get; set; }
State state { get; set; }
// ...
}
class State
{
int id { get; set; }
string name { get; set; }
// ...
}
我对引用实体的地址组件感到有点不舒服。闻起来像一个糟糕的模特。是吗?如果没有,我将如何映射(最好是流利的nhibernate)?
答案 0 :(得分:2)
我也不确定如何从组件引用实体。我自己这样做了(有一个国家实体,不能少)。
就映射而言,它非常简单:
public class MyEntityMap : ClassMap<MyEntity>
{
public MyEntityMap()
{
Id(x => x.id);
Component<Address>(x => x.location, c =>
{
c.Map(x => x.street);
c.Map(x => x.zip);
c.References<State>(x => x.state);
});
Map(x => x.status);
}
}
有时我所做的是为组件添加一个静态类,使ClassMap更好一些:
public static class NameMap
{
public static Action<ComponentPart<Name>> AsComponent(string prefix)
{
return c =>
{
c.Map(x => x.Title, ColumnName(prefix, "Title"));
// and so on
};
}
}
在这种情况下,ColumnName是一个简单的函数,它将前缀附加到列名称(这在我可以使用的精彩遗留数据库中非常方便)。
然后在ClassMap中你做:
Component<Name>(x => x.Name, c => NameMap.AsComponent("prefix"));