Heim >Datenbank >MySQL-Tutorial >Wie kann ich überlappende Datumsbereiche in PostgreSQL effizient finden?

Wie kann ich überlappende Datumsbereiche in PostgreSQL effizient finden?

Susan Sarandon
Susan SarandonOriginal
2025-01-05 10:41:40714Durchsuche

How Can I Efficiently Find Overlapping Date Ranges in PostgreSQL?

Überlappende Datumsbereiche in PostgreSQL finden

Bei der Arbeit mit Datumsbereichen in PostgreSQL ist das Identifizieren von Überschneidungen eine entscheidende Aufgabe. Die bereitgestellte Abfrage versucht, Spieler zu finden, die in bestimmten Jahren in einem Team waren, enthält jedoch Fehler.

Das Problem mit der bereitgestellten Abfrage

Die Abfrage enthält eine ZWISCHEN-Bedingung ( DATE_PART('YEAR',date_join) >= ? AND DATE_PART('YEAR',date_leave) <= ?), das prüft, ob Die Jahreskomponenten der Spalten date_join und date_leave liegen innerhalb des angegebenen Bereichs. Es werden jedoch fälschlicherweise die Operatoren >= und <= verwendet, die die Obergrenze (Ende des Jahres) einschließen.

Die korrigierte Abfrage

Um Überlappungen korrekt zu finden Bereiche müssen wir die Bedingungen anpassen, um die Obergrenze auszuschließen:

SELECT * 
FROM   contract 
JOIN   team USING (name_team) 
JOIN   player USING(name_player) 
WHERE  name_team = ? 
AND    DATE_PART('YEAR',date_join) >= ? 
AND    DATE_PART('YEAR',date_leave) < ?</p>
<p><strong>Alternative Lösung mit Bereich Typen</strong></p>
<p>PostgreSQL-Versionen 9.2 und höher bieten Unterstützung für Bereichstypen. Hier ist eine Abfrage, die einen Bereichstyp und den Operator &&& verwendet, um überlappende Bereiche zu finden:</p>
<pre class="brush:php;toolbar:false">SELECT DISTINCT name_player 
FROM   contract
WHERE  name_team = ? 
AND    daterange(date_join, date_leave) &&&
       daterange '[2009-01-01,2010-01-01)'

Diese Abfrage nutzt den Überlappungsoperator &&& und einen speziell definierten Bereichstyp, um überlappende Datumsbereiche zu finden, ohne dass eine explizite Grenze erforderlich ist Schecks.

Das obige ist der detaillierte Inhalt vonWie kann ich überlappende Datumsbereiche in PostgreSQL effizient finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn