0


0

Récupérer le nom de la propriété à partir du nom de la colonne parfaitement mappé

Contexte

J’ai une classe appelée «Dog», qui fait référence à une autre classe appelée «Tail», qui a une propriété appelée «Size». Donc, si je voulais connaître la taille de la queue du chien, ce serait «Dog.Tail.Size». Parfait.

J’ai ceci mappé avec FluentNHibernate comme ceci:

 public class DogMap : ClassMap
 {
    public DogMap()
    {
        ... other things here
        Component(x => x.Tail, t => {
            t.Map(x => x.Size, "DG_TL_SIZE").Length(2).Not.Nullable();
        }
    }
 }

La question

Ayant le nom de colonne "DG_TL_SIZE", comment puis-je obtenir "Dog.Tail.Size"? Je sais que je peux, après avoir Dog.Tail.Size, obtenir le "" persistentClass.GetRecursiveProperty ("Dog.Tail.Size") "` pour récupérer la propriété et travailler avec elle.

Le fait est que je dois changer sa valeur, donc j’ai besoin d’un PropertyInfo à partir de cela, mais cela ne devrait pas être difficile à obtenir quand j’ai "Dog.Tail.Size".

Alors, * comment puis-je obtenir le "Dog.Tail.Size"? *

1 Answer


0


vous pouvez parcourir toutes les propriétés, le code présenté doit cependant être refactorisé

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