Jor*_*ran 6 nhibernate components fluent-nhibernate automapping value-objects
我的所有实体和值对象都实现了标记接口IEntity和IValueObject.我把它们设置为像这样的组件:
public override bool IsComponent(Type type)
{
return typeof(IValueObject).IsAssignableFrom(type);
}
public override bool ShouldMap(Type type)
{
return typeof(IEntity).IsAssignableFrom(type) || typeof(IValueObject).IsAssignableFrom(type);
}
Run Code Online (Sandbox Code Playgroud)
不幸的是,这似乎不允许将具有值对象集合的实体自动化为组件集合.例如:
public class MyEntity : IEntity
{
public IList<MyValueObject> Objects { get; set; }
}
public class MyValueObject : IValueObject
{
public string Name { get; set; }
public string Value { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
有没有办法定义一个约定,这样,只要IEntity有IList一个类型实现IValueObject,它就像我指定的那样被映射:
HasMany(x => x.Objects)
.Component(x => {
x.Map(m => m.Name);
x.Map(m => m.Value);
});
Run Code Online (Sandbox Code Playgroud)
我不想做的是必须为每个类手动执行这些覆盖,并一次又一次地为值对象写出每个属性.
使用以下内容重写 ShouldMap() 方法:
return base.ShouldMap(member) && IsCollectionOfComponents(member)
Run Code Online (Sandbox Code Playgroud)将您的逻辑添加到:
public void Map(ClassMappingBase classMap, Member member)
{ ... }
Run Code Online (Sandbox Code Playgroud)将默认步骤替换为新步骤:
public class MyMappingConfiguration : DefaultAutomappingConfiguration
{
public override IEnumerable<IAutomappingStep> GetMappingSteps(AutoMapper mapper, IConventionFinder conventionFinder)
{
var steps = base.GetMappingSteps(mapper, conventionFinder);
var finalSteps = steps.Where(c => c.GetType() != typeof(FluentNHibernate.Automapping.Steps.HasManyToManyStep)).ToList();
var idx = finalSteps.IndexOf(steps.Where(c => c.GetType() == typeof(PropertyStep)).First());
finalSteps.Insert(idx + 1, new MyCustomHasManyStep(this));
return finalSteps;
}
}
Run Code Online (Sandbox Code Playgroud)注意:您还可以获取 HasManyStep.cs 的原始源代码并将其复制到您的项目中以引入您的自定义逻辑。
| 归档时间: |
|
| 查看次数: |
760 次 |
| 最近记录: |