Ü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!