从Fluently映射的列名中检索属性名称
本文关键字:检索 属性 Fluently 映射 | 更新日期: 2023-09-27 18:11:54
背景
我有一个叫"Dog"的类,它引用了另一个名为"Tail"的类。所以,如果我想知道这只狗的尾巴大小,它应该是"狗。尾巴。大小"。完美。
我已经用FluentHibernate这样映射了:
public class DogMap : ClassMap<Dog>
{
public DogMap()
{
... other things here
Component(x => x.Tail, t => {
t.Map(x => x.Size, "DG_TL_SIZE").Length(2).Not.Nullable();
}
}
}
问题
列名为"DG_TL_SIZE",如何获得"Dog.Tail.SIZE"?我知道,在我有了Dog.Tail.Size之后,我可以让"persistentClass.GetRecursiveProperty("Dog.Tail.Size")"
检索属性并使用它。
问题是我需要更改它的值,因此我需要一个PropertyInfo,但当我有"Dog.Tail.Size"时,这应该不难获得。
那么,如何获取"Dog.Tail.Size">
您可以遍历所有属性,所呈现的代码需要通过进行重构
foreach (var prop in persistentclass.PropertyClosureIterator)
{
IValue property = prop.Value;
if (prop.IsComposite)
{
var component = (NHibernate.Mapping.Component)prop.Value;
foreach (var prop2 in component.PropertyIterator)
{
foreach (var column in prop2.ColumnIterator)
{
if (column.Text == "my Column")
{
// do something with the 'prop2'
}
}
}
}
else
{
foreach (var column in prop.ColumnIterator)
{
if (column.Text == "my Column")
{
// do something with the 'prop'
}
}
}
}