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

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

Susan Sarandon
Susan Sarandon원래의
2025-01-15 06:35:43794검색

How to Retrieve Requests with the Latest Successful Response Using 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>

이 작업은 최신 응답(타임스탬프 기준)으로 성공한 모든 요청을 검색하는 쿼리를 구성하는 것입니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.