Name

ST_Within — Tests, wenn jeder Punkt von A in B liegt und ihre Innenräume einen gemeinsamen Punkt haben

Synopsis

boolean ST_Within(geometry A, geometry B);

Beschreibung

Gibt TRUE zurück, wenn Geometrie A innerhalb von Geometrie B liegt. A liegt nur dann innerhalb von B, wenn alle Punkte von A innerhalb (d. h. im Inneren oder am Rand) von B liegen (oder gleichwertig, keine Punkte von A liegen im Äußeren von B) und die Innenräume von A und B mindestens einen Punkt gemeinsam haben.

Damit diese Funktion sinnvoll ist, müssen die Ausgangsgeometrien beide die gleiche Koordinatenprojektion und den gleichen SRID haben.

Mathematisch ausgedrückt: ST_Within(A, B) ⇔ (A ⋂ B = A) ∧ (Int(A) ⋂ Int(B) ≠ ∅)

Die Within-Relation ist reflexiv: jede Geometrie ist in sich selbst. Die Beziehung ist antisymmetrisch: Wenn ST_Within(A,B) = true und ST_Within(B,A) = true, dann müssen die beiden Geometrien topologisch gleich sein (ST_Equals(A,B) = true).

ST_Within ist die Umkehrung von ST_Contains. ST_Within(A,B) = ST_Contains(B,A).

[Note]

Da die Innenräume einen gemeinsamen Punkt haben müssen, besteht eine Feinheit der Definition darin, dass Linien und Punkte, die vollständig in der Begrenzung von Polygonen oder Linien liegen, nicht innerhalb der Geometrie sind. Für weitere Details siehe Subtleties of OGC Covers, Contains, Within. Das Prädikat ST_CoveredBy bietet eine umfassendere Beziehung.

[Note]

Diese Funktion beinhaltet automatisch einen Bounding-Box-Vergleich, der alle räumlichen Indizes verwendet, die für die Geometrien verfügbar sind. Um die Verwendung von Indizes zu vermeiden, verwenden Sie die Funktion _ST_Within.

Wird durch das GEOS Modul ausgeführt

Verbessert: 2.3.0 Verbesserung des PIP-Kurzschlusses für Geometrien, erweitert um die Unterstützung von MultiPoints mit wenigen Punkten. Frühere Versionen unterstützten nur Punkte in Polygonen.

[Important]

Verbessert: 3.0.0 ermöglicht die Unterstützung von GEOMETRYCOLLECTION

[Important]

Verwenden Sie diese Funktion nicht mit ungültigen Geometrien. Sie werden unerwartete Ergebnisse erhalten.

HINWEIS: Dies ist die "zulässige" Version, die einen booleschen Wert und keine ganze Zahl zurückgibt.

Diese Methode implementiert die OGC Simple Features Implementation Specification for SQL 1.1. s2.1.1.2 // s2.1.13.3 - a.Relate(b, "T*F**F***")

Diese Methode setzt die SQL/MM-Spezifikation um. SQL-MM 3: 5.1.30

Beispiele

--a circle within a circle
SELECT ST_Within(smallc,smallc) As smallinsmall,
  ST_Within(smallc, bigc) As smallinbig,
  ST_Within(bigc,smallc) As biginsmall,
  ST_Within(ST_Union(smallc, bigc), bigc) as unioninbig,
  ST_Within(bigc, ST_Union(smallc, bigc)) as biginunion,
  ST_Equals(bigc, ST_Union(smallc, bigc)) as bigisunion
FROM
(
SELECT ST_Buffer(ST_GeomFromText('POINT(50 50)'), 20) As smallc,
  ST_Buffer(ST_GeomFromText('POINT(50 50)'), 40) As bigc) As foo;
--Result
 smallinsmall | smallinbig | biginsmall | unioninbig | biginunion | bigisunion
--------------+------------+------------+------------+------------+------------
 t            | t          | f          | t          | t          | t
(1 row)