Проблема с критериями создания в nhibernate - PullRequest
0 голосов
/ 02 ноября 2009

У меня есть право на

public class ClaimDetail
{
   public virtual int Id { get; set; }
   public virtual Claim Claim {get;set;}
   public virtual string ServiceDateFrom { get; set; }      
   public virtual string DateCreated { get; set; }
   public virtual ClaimDetail ParentClaimDetail { get; set; }
}

Я хочу применить левое внешнее соединение к этой таблице как

SELECT cd.ClaimDetailId ,
cd.ParentClaimDetail_id  ,
cds.ClaimDetailId  ,
cds.ParentClaimDetail_id  ,
cds.DateCreated,
cd.DateCreated
 FROM ClaimDetail AS cd left JOIN ClaimDetail AS cds ON 
cd.ClaimDetailId = cds.ParentClaimDetail_id

Я реализую этот запрос в nhibernate как

ICriteria query = session.CreateCriteria(typeof(ClaimDetail), "cd") 
    .CreateAlias("ParentClaimDetail", "cds", NHibernate.SqlCommand.JoinType.LeftOuterJoin);
query.SetProjection
              (
                     Projections.ProjectionList()
                       .Add(Projections.Property("cd.ParentClaimDetail.Id"), "sks")
                       .Add(Projections.Property("cd.Id"),"cdid")
                       .Add(Projections.Property("cds.DateCreated"), "dc1")
                       .Add(Projections.Property("cd.DateCreated"), "dc2")
                       .Add(Projections.Property("cds.ParentClaimDetail.Id"), "cds")
                       .Add(Projections.Property("cds.Id"),"cdsid")
              );

но это создает критерий создания запроса как

SELECT cd.ClaimDetailId ,
cd.ParentClaimDetail_id  ,
cds.ClaimDetailId  ,
cds.ParentClaimDetail_id  ,
cds.DateCreated,
cd.DateCreated
 FROM ClaimDetail AS cd left JOIN ClaimDetail AS cds ON 
cd.ParentClaimDetail_id = cds.ClaimDetailId

Может ли кто-нибудь помочь мне.

Заранее спасибо

1 Ответ

0 голосов
/ 02 ноября 2009

Похоже, вы хотите использовать именованный запрос вместо. Именованный запрос входит в отображающий XML, и вы можете вводить в него входные данные. Кроме того, вы можете выбрать пользовательский класс для представления сущностей результирующих данных.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...