> 백엔드 개발 > C++ > NHibernate를 사용하여 최근에 성공한 응답으로만 요청을 검색하는 방법은 무엇입니까?

NHibernate를 사용하여 최근에 성공한 응답으로만 요청을 검색하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-15 10:20:44
원래의
580명이 탐색했습니다.

How to Retrieve Requests with Only the Latest Successful Response Using NHibernate?

NHibernate를 사용하여 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>
로그인 후 복사

쿼리 작성:

원하는 결과를 얻기 위해 하위 쿼리를 활용하는 NHibernate QueryOver 쿼리를 생성할 수 있습니다.

<code class="language-c#">// 响应子查询,查找最大日期响应
var maxSubquery = QueryOver.Of<Response>()
    .SelectList(l => l
        .SelectGroup(item => item.RequestId)
        .SelectMax(item => item.Timestamp))
    .Where(item => item.RequestId == response.RequestId)
    .Where(Restrictions.EqProperty(
        Projections.Max<Response>(item => item.Timestamp),
        Projections.Property(() => response.Timestamp)));

// 响应子查询,查找具有最大日期的成功响应
var successSubquery = QueryOver.Of<Response>()(() => response)
    .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>
로그인 후 복사

쿼리 지침:

  • maxSubquery 각 요청에 대한 최대 응답 날짜를 찾으세요.
  • successSubquery 성공했고 해당 요청에 대한 최대 날짜가 있는 응답만 포함하도록 응답을 필터링합니다.
  • 그런 다음 기본 쿼리는 successSubquery에서 식별된 성공적인 응답의 가용성을 기준으로 요청을 필터링합니다.

또는 쿼리를 단순화하려면 응답에 "IsActive" 속성을 설정하는 것이 좋습니다.

위 내용은 NHibernate를 사용하여 최근에 성공한 응답으로만 요청을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿