ho classe di dominio posizioneNHibernate proiezione sopra nidificati proprietà nidificate
public abstract class BaseEntity<T> where T: struct
{
public virtual T Id { get; set; }
public virtual bool Equals(BaseEntity<T> other)
}
public class Location : BaseEntity<Int32>
{
public User User {get;set;}
}
public class User : BaseEntity<Int32>
{
public string Name {get;set;
}
public OtherInfo Otherinfo {get;set;};
}
public class OtherInfo
{
public string preference {get;set;};
}
var criteria = session.CreateCriteria(typeof(Location), "alias");
criteria.CreateCriteria("User", "user", JoinType.InnerJoin);
criteria.CreateCriteria("user.Otherinfo", "userInfo",JoinType.InnerJoin);
criteria.Add(Restrictions.Eq("user.Id", 100));
criteria.SetProjection(Projections.Alias(Projections.Id(), "Id"), Projections.Alias(Projections.Property("user.Name"), "Name"), Projections.Alias(Projections.Property("userInfo.preference "), "pref"));
ora quando eseguo sopra criteri, dà errore userInfo.preference. {NHibernate.QueryException: impossibile risolvere la proprietà: Otherinfo di: Location.User Che cos'è l'errore qui. è a causa di multi oggetti nidificati
era solo la mia errore di battitura durante la pubblicazione domanda, nel codice sua corretta. – Techmaster
hai qualche altro indizio, per favore fammi sapere, sono colpito da molto tempo. – Techmaster
Sì, certo - usa CreateAlias invece di CreateCriteria - CreateCriteria ti sposterà verso il basso l'associazione, CreateAlias è più naturale - ha aggiornato l'esempio –