ST_PolyFromWKB

Definition

Mit ST_PolyFromWKB wird anhand eines Well-known Binary-Formats (WKB) und einer Raumbezugs-ID ein ST_Polygon-Objekt zurückgegeben.

Syntax

Oracle

sde.st_polyfromwkb (wkb blob, srid integer)

PostgreSQL

sde.st_polyfromwkb (wkb bytea, srid integer)

Rückgabetyp

ST_Polygon

Beispiel

Im folgenden Beispiel wurden die Zeilen der Ergebnisse zur besseren Lesbarkeit neu formatiert. Die Abstände der Ihnen angezeigten Ergebnisse können abhängig von Ihrer Online-Darstellung variieren. In diesem Beispiel wird veranschaulicht, wie ST_PolyFromWKB zum Erstellen eines Polygons aus einem Well-known Binary-Format verwendet werden kann. Die Geometrie ist ein Polygon im Raumbezugssystem 1. In diesem Beispiel wird das Polygon mit der ID = 1115 in der Spalte "geometry " der Tabelle "sample_polys" gespeichert; anschließend wird die Spalte "wbk" mit der WBK-Repräsentation (mithilfe der Funktion ST_AsBinary) aktualisiert. Zum Schluss wird mit der ST_PolyFromWKB-Funktion das Polygon aus der Spalte "WBK" zurückgegeben. Die X- und Y-Koordinaten dieser Geometrie lauten (50, 20) (50, 40) (70, 30). Die Tabelle "sample_polys" verfügt über die Spalte "geometry", in der das Polygon gespeichert wird, sowie über die Spalte "wbk", in der die WBK-Repräsentation des Polygons gespeichert wird.

Oracle

CREATE TABLE sample_polys (id integer, geometry sde.st_geometry, wkb blob);

INSERT INTO SAMPLE_POLYS (id, geometry) VALUES (
1115,
sde.st_polyfromtext ('polygon ((10.01 20.03, 10.52 40.11, 30.29 41.56,
31.78 10.74, 10.01 20.03))', 0)
);

UPDATE SAMPLE_POLYS
SET wkb = sde.st_asbinary (geometry)
WHERE id = 1115;

PostgreSQL

CREATE TABLE sample_polys (id integer, geometry sde.st_geometry, wkb bytea);

INSERT INTO sample_polys (id, geometry) VALUES (
1115,
sde.st_polygon ('polygon  ((10.01 20.03, 10.52 40.11, 30.29 41.56,
31.78 10.74, 10.01 20.03))', 0)
);

UPDATE sample_polys
SET wkb = sde.st_asbinary (geometry)
WHERE id = 1115;

In der folgenden SELECT-Anweisung werden die Punkte mit der ST_PointFromWKB-Funktion aus der Spalte "WBK" abgerufen.

Oracle

SELECT id, sde.st_astext (sde.st_polyfromwkb (wkb, 0)) POLYS
FROM SAMPLE_POLYS;

ID    	POLYS

1115    POLYGON (10.01000000 20.03000000, 31.78000000 10.74000000, 30.29000000 41.56000000, 10.52000000 40.11000000, 10.01000000 20.03000000)

PostgreSQL

SELECT id, sde.st_astext (sde.st_polyfromwkb (wkb, 0)) 
AS POLYS
FROM sample_polys;

id    polys

1115    POLYGON (10.01000000 20.03000000, 31.78000000 10.74000000, 30.29000000 41.56000000, 10.52000000 40.11000000, 10.01000000 20.03000000)

7/10/2012