HasMany 쿼리: 최근 성공한 응답으로 요청 가져오기
다음 솔리드 모델을 고려해보세요.
<code class="language-c#">public class Request { public virtual IList<Response> Responses { get; set; } } public class Response { public virtual DateTime Timestamp { get; set; } public virtual bool Success { get; set; } }</code>
이 작업은 최신 응답(타임스탬프 기준)으로 성공한 모든 요청을 검색하는 쿼리를 구성하는 것입니다.
QueryOver를 이용한 NHibernate 솔루션
NHibernate는 QueryOver를 사용하여 포괄적인 솔루션을 제공합니다.
<code class="language-c#">Response responseAlias = null; var maxSubquery = QueryOver.Of<Response>() .SelectList(l => l .SelectGroup(item => item.RequestId) .SelectMax(item => item.Timestamp) // 使用 Timestamp 而不是 DateTime ) .Where(item => item.RequestId == responseAlias.RequestId) .Where(Restrictions.EqProperty( Projections.Max<Response>(item => item.Timestamp), // 使用 Timestamp 而不是 DateTime Projections.Property(() => responseAlias.Timestamp) // 使用 Timestamp 而不是 DateTime )); var successSubquery = QueryOver.Of<Response>(() => responseAlias) .Select(res => res.RequestId) .WithSubquery .WhereExists(maxSubquery) .Where(success => success.Success == true); var query = session.QueryOver<Request>(); query.WithSubquery .WhereProperty(r => r.ID) .In(successSubquery); var list = query.List<Request>();</code>
이 쿼리는 성공적인 응답이 하나 이상 있는 모든 요청을 검색합니다(타임스탬프를 기준으로 가장 최근 응답). 코드에서 DateTime
를 보다 정확한 Timestamp
으로 교체했으며, 가독성을 높이기 위해 변수 이름을 약간 조정했습니다. 핵심 논리는 동일하게 유지됩니다.
위 내용은 NHibernate를 사용하여 최근에 성공한 응답으로 요청을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!