ST_Crosses — Prüft, ob zwei Geometrien einige, aber nicht alle, innere Punkte gemeinsam haben
boolean ST_Crosses(
geometry g1, geometry g2)
;
Vergleicht zwei Geometrieobjekte und gibt true
zurück, wenn sich ihre Schnittpunkte "räumlich kreuzen"; das heißt, die Geometrien haben einige, aber nicht alle Innenpunkte gemeinsam. Die Schnittmenge der Innenräume der Geometrien darf nicht leer sein und muss eine Dimension haben, die kleiner ist als die maximale Dimension der beiden Eingabegeometrien, und die Schnittmenge der beiden Geometrien darf keiner der beiden Geometrien entsprechen. Andernfalls gibt es false
zurück. Die Kreuzungsbeziehung ist symmetrisch und irreflexiv.
Mathematisch ausgedrückt: ST_Crosses(A, B) ⇔ (dim( Int(A) ⋂ Int(B) ) < max( dim( Int(A) ), dim( Int(B) ) )) ∧ (A ⋂ B ≠ A) ∧ (A ⋂ B ≠ B)
Geometrien kreuzen sich, wenn ihre DE-9IM Schnittpunktmatrix übereinstimmt:
T*T******
für die Situationen Punkt/Linie, Punkt/Fläche und Linie/Fläche
T*****T**
für die Situationen Linie/Punkt, Bereich/Punkt und Bereich/Linie
0********
für Line/Line-Situationen
das Ergebnis ist falsch
für Punkt/Punkt und Bereich/Fläche Situationen
Die OpenGIS Simple Features Specification definiert dieses Prädikat nur für die Situationen Punkt/Linie, Punkt/Fläche, Linie/Linie und Linie/Fläche. JTS / GEOS erweitert die Definition so, dass sie auch für die Situationen Linie/Punkt, Fläche/Punkt und Fläche/Linie gilt. Dadurch wird die Beziehung symmetrisch. |
Diese Funktion beinhaltet automatisch einen Bounding-Box-Vergleich, der alle räumlichen Indizes verwendet, die für die Geometrien verfügbar sind. |
Verbessert: 3.0.0 ermöglicht die Unterstützung von |
Diese Methode implementiert die OGC Simple Features Implementation Specification for SQL 1.1. s2.1.13.3
Diese Methode setzt die SQL/MM-Spezifikation um. SQL-MM 3: 5.1.29
Die folgenden Situationen ergeben alle true
.
|
|
|
|
Stellen Sie sich eine Situation vor, in der ein Benutzer zwei Tabellen hat: eine Tabelle mit Straßen und eine Tabelle mit Autobahnen.
CREATE TABLE roads ( id serial NOT NULL, geom geometry, CONSTRAINT roads_pkey PRIMARY KEY (road_id) );
|
CREATE TABLE highways ( id serial NOT NULL, the_gem geometry, CONSTRAINT roads_pkey PRIMARY KEY (road_id) );
|
Um eine Liste von Straßen zu ermitteln, die eine Autobahn kreuzen, verwenden Sie eine Abfrage, die der folgenden ähnelt:
SELECT roads.id FROM roads, highways WHERE ST_Crosses(roads.geom, highways.geom);