Definition
Mit ST_PolyFromWKB wird anhand einer Repräsentation im WKB-Format (Well-Known Binary) und einer Raumbezugs-ID ein ST_Polygon-Objekt zurückgegeben.
Syntax
Oracle
sde.st_polyfromwkb (wkb blob, srid integer)
sde.st_polyfromwkb (wkb blob)
Wenn Sie keine SRID angeben, ist der standardmäßige Raumbezug 4326.
PostgreSQL
sde.st_polyfromwkb (wkb bytea, srid integer)
SQLite
st_polyfromwkb (wkb blob, srid int32)
st_polyfromwkb (wkb blob)
Wenn Sie keine SRID angeben, ist der standardmäßige Raumbezug 4326.
Rückgabetyp
ST_Polygon
Beispiel
In diesem Beispiel wird veranschaulicht, wie ST_PolyFromWKB zum Erstellen eines Polygons aus seiner WKB-Repräsentation (Well-Known Binary) verwendet werden kann. Bei der Geometrie handelt es sich um ein Polygon im Raumbezugssystem 4326. In diesem Beispiel wird das Polygon mit der ID = 1115 in der Spalte "geometry" der Tabelle "sample_polys" gespeichert. Anschließend wird die Spalte "wkb" mit dem WKB-Format (mithilfe der Funktion "ST_AsBinary") aktualisiert. Zum Schluss wird mit der ST_PolyFromWKB-Funktion das Polygon aus der Spalte "WBK" zurückgegeben. 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.
In der SELECT-Anweisung werden die Punkte mit der ST_PointFromWKB-Funktion aus der Spalte "WBK" abgerufen.
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))', 4326)
);
UPDATE SAMPLE_POLYS
SET wkb = sde.st_asbinary (geometry)
WHERE id = 1115;
SELECT id, sde.st_astext (sde.st_polyfromwkb (wkb, 4326)) 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
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))', 4326)
);
UPDATE sample_polys
SET wkb = sde.st_asbinary (geometry)
WHERE id = 1115;
SELECT id, sde.st_astext (sde.st_polyfromwkb (wkb, 4326))
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)
SQLite
CREATE TABLE sample_polys(
id integer,
wkb blob
);
SELECT AddGeometryColumn(
NULL,
'sample_polys',
'geometry',
4326,
'polygon',
'xy',
'null'
);
INSERT INTO sample_polys (id, geometry) VALUES (
1115,
st_polyfromtext ('polygon ((10.01 20.03, 10.52 40.11, 30.29 41.56, 31.78 10.74, 10.01 20.03))', 4326)
);
UPDATE sample_polys
SET wkb = st_asbinary (geometry)
WHERE id = 1115;
SELECT id, st_astext (st_polyfromwkb (wkb, 4326))
AS "polygons"
FROM sample_polys;
id polygons
1115 POLYGON (10.01000000 20.03000000, 31.78000000 10.74000000, 30.29000000 41.56000000, 10.52000000 40.11000000, 10.01000000 20.03000000)