Доступ к NHibernate Entity через проекцию

У меня есть этот файл сопоставления:

'class name="WebTools.Data.Common.IHObjekt, WebTools.Data" table="IHObjekt"'  
  ....
'property name="TYPBEZEICH" type="string"' 
...  
'many-to-one name="standort" column="STANDORT_ID" fetch="join"'  

И я хотел бы использовать «Projections.ProjectionList()», чтобы уменьшить количество возвращаемых столбцов из запроса.

Я сделаю это:

'ICriteria criteria = Session.CreateCriteria(typeof(Data.Common.IHObjekt));'  
'ProjectionList projectionList = Projections.ProjectionList();'  
..   
'projectionList.Add(Projections.Property("standort.CODE"));'  

И получить эту ошибку:

NHibernate.QueryException: не удалось разрешить свойство: standort.CODE из: WebTools.Data.Common.IHObjekt

Я пытаюсь получить доступ к дочернему объекту, но, похоже, я могу получить доступ только к значениям в своем родительском классе. Нравиться:

'projectionList.Add(Projections.Property("TYPBEZEICH"));' 

Может ли кто-нибудь предоставить код, который позволит мне использовать проекцию для доступа к объекту в дочернем классе?


person Ben    schedule 13.10.2010    source источник


Ответы (1)


Вам необходимо создать псевдоним, чтобы ссылаться на свойства дочернего объекта.

ICriteria criteria = Session.CreateCriteria(typeof(Data.Common.IHObjekt));

criteria.CreateAlias("standort", "s", JoinType.InnerJoin);

ProjectionList projectionList = Projections.ProjectionList();
projectionList.Add(Projections.Property("s.CODE"));
person iammichael    schedule 13.12.2010