0

NHibernate に次の SQL を生成してもらいたいのですが、以下のコードに苦労しています。

SELECT * FROM [TCRM_Client] where (
 [ID] in (  
  SELECT B.ClientID FROM TCRM_Contact A,R_Client_Contact B
  WHERE A.ID = B.ContactID
  AND (
        A.Mobile LIKE 'KEYWORD%' OR A.Tel LIKE 'KEYWORD%'
      )  
  )
 OR Name LIKE '%KEYWORD%'
)



private void AddCriterion<T>(IQueryOver<T, T> query)
         where T : Client
{
    if (!String.IsNullOrEmpty(keyWord))
    {
        var r1 = (Restrictions.On<Client>(x => x.Name)
          .IsLike("%" + keyWord + "%", MatchMode.Start));
        var profilequery = query.Left.JoinQueryOver<ClientContact>
          (o => o.ClientContactList)
          .Left.JoinQueryOver<Contact>(x => x.Contact).Where(o => o.ID != Guid.Empty);
        var r2 = Restrictions.On<Contact>(x => x.Tel)
          .IsLike("%" + keyWord + "%", MatchMode.Start) || 
          Restrictions.On<Contact>(x => x.Mobile)
          .IsLike("%" + keyWord + "%",MatchMode.Start);

        //A failed attempt
        //query.Add(r1)
        //profilequery.Add(r2);


        //Another failed attempt
        //query.RootCriteria.Add(Restrictions.Or(r1,r2));
    }
}

現在、異なるテーブル間でキーワード「OR」を使用していないため、これらのコードは機能しません。

4

1 に答える 1