Anfragen mit der aktuellsten erfolgreichen Antwort mit NHibernate QueryOver abrufen
Dieses Beispiel zeigt eine ausgefeilte NHibernate QueryOver-Abfrage zum Abrufen aller Request
-Entitäten, die jeweils mit ihrem letzten erfolgreichen Response
verknüpft sind. Die Request
-Entität verfügt über eine Sammlung von Response
-Entitäten. Unser Ziel ist es, nur das Request
zusammen mit seinem letzten erfolgreichen Response
abzurufen, basierend auf dem Response
des Timestamp
.
Die folgende Lösung verwendet verschachtelte Unterabfragen, um diesen komplexen Abruf zu erreichen. Ein einfacherer Ansatz könnte möglich sein, wenn die Response
-Entität ein „IsActive“-Flag enthalten würde.
Hier ist die NHibernate QueryOver-Implementierung:
<code class="language-c#">// Reference to a Response entity Response responseAlias = null; // Subquery to find the maximum DateTime for each RequestId var maxTimestampSubquery = QueryOver.Of<Response>(() => responseAlias) .SelectList(l => l .SelectGroup(() => responseAlias.RequestId) .SelectMax(() => responseAlias.DateTime) ); // Subquery to find successful Responses with the maximum DateTime var successfulResponseSubquery = QueryOver.Of<Response>(() => responseAlias) .Where(() => responseAlias.Success == true) .WithSubquery .WhereProperty(() => responseAlias.DateTime).In(maxTimestampSubquery); // Main query to retrieve Requests with successful Responses var query = session.QueryOver<Request>(); query.WithSubquery .WhereProperty(r => r.Id) .In(successfulResponseSubquery.Select(r => r.RequestId)); var requests = query.List<Request>();</code>
Dieser Code verwendet Unterabfragen, um die relevanten Response
-Entitäten effizient zu identifizieren und sie mit den entsprechenden Request
-Entitäten zu verknüpfen. Das maxTimestampSubquery
findet den neuesten Zeitstempel für jede Anfrage und das successfulResponseSubquery
filtert nach erfolgreichen Antworten, die diesen Zeitstempeln entsprechen. Die Hauptabfrage ruft dann die Request
-Entitäten basierend auf den IDs ab, die in der Unterabfrage mit erfolgreicher Antwort gefunden wurden. Denken Sie daran, Request
und Response
durch Ihre tatsächlichen Entitätsnamen zu ersetzen und die Eigenschaftsnamen entsprechend anzupassen.
Das obige ist der detaillierte Inhalt vonWie kann ich mit NHibernate QueryOver Anfragen mit ihrer letzten erfolgreichen Antwort abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!