从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">

从Fluently映射的列名中检索属性名称

您可以遍历所有属性,所呈现的代码需要通过进行重构

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'
            }
        }
    }
}