ST_IsValidDetail — Gibt eine Zeile valid_detail zurück, die angibt, ob eine Geometrie gültig ist oder, falls nicht, einen Grund und einen Ort.
valid_detail ST_IsValidDetail(geometry geom, integer flags);
Gibt eine Zeile valid_detail zurück, die einen booleschen Wert (valid) enthält, der angibt, ob eine Geometrie gültig ist, einen varchar-Wert (reason), der einen Grund angibt, warum sie ungültig ist, und eine Geometrie (location), die angibt, wo sie ungültig ist.
Nützlich zur Verbesserung der Kombination von ST_IsValid und ST_IsValidReason, um einen detaillierten Bericht über ungültige Geometrien zu erstellen.
Der optionale Parameter flags ist ein Bitfeld. Er kann die folgenden Werte haben:
0: Verwendung der üblichen OGC SFS-Gültigkeitssemantik.
1: Bestimmte Arten von sich selbst berührenden Ringen (umgekehrte Schalen und umgekehrte Löcher) als gültig betrachten. Dies ist auch als "ESRI-Flagge" bekannt, da dies das von diesen Werkzeugen verwendete Gültigkeitsmodell ist. Beachten Sie, dass dies nach dem OGC-Modell ungültig ist.
Wird vom GEOS Modul ausgeführt
Verfügbarkeit: 2.0.0
--First 3 Rejects from a successful quintuplet experiment
SELECT gid, reason(ST_IsValidDetail(geom)), ST_AsText(location(ST_IsValidDetail(geom))) as location
FROM
(SELECT ST_MakePolygon(ST_ExteriorRing(e.buff), array_agg(f.line)) As geom, gid
FROM (SELECT ST_Buffer(ST_Point(x1*10,y1), z1) As buff, x1*10 + y1*100 + z1*1000 As gid
FROM generate_series(-4,6) x1
CROSS JOIN generate_series(2,5) y1
CROSS JOIN generate_series(1,8) z1
WHERE x1
> y1*0.5 AND z1 < x1*y1) As e
INNER JOIN (SELECT ST_Translate(ST_ExteriorRing(ST_Buffer(ST_Point(x1*10,y1), z1)),y1*1, z1*2) As line
FROM generate_series(-3,6) x1
CROSS JOIN generate_series(2,5) y1
CROSS JOIN generate_series(1,10) z1
WHERE x1
> y1*0.75 AND z1 < x1*y1) As f
ON (ST_Area(e.buff)
> 78 AND ST_Contains(e.buff, f.line))
GROUP BY gid, e.buff) As quintuplet_experiment
WHERE ST_IsValid(geom) = false
ORDER BY gid
LIMIT 3;
gid | reason | location
------+-------------------+-------------
5330 | Self-intersection | POINT(32 5)
5340 | Self-intersection | POINT(42 5)
5350 | Self-intersection | POINT(52 5)
--simple example
SELECT * FROM ST_IsValidDetail('LINESTRING(220227 150406,2220227 150407,222020 150410)');
valid | reason | location
-------+--------+----------
t | |