Определение
ST_PolyFromWKB принимает WKB-представление и идентификатор пространственной привязки и возвращает ST_Polygon.
Синтаксис
Oracle
sde.st_polyfromwkb (wkb blob, srid integer)
sde.st_polyfromwkb (wkb blob)
Если вы не указали SRID, пространственная привязка по умолчанию будет 4326.
PostgreSQL
sde.st_polyfromwkb (wkb bytea, srid integer)
SQLite
st_polyfromwkb (wkb blob, srid int32)
st_polyfromwkb (wkb blob)
Если вы не указали SRID, пространственная привязка по умолчанию будет 4326.
Тип возвращаемого значения
ST_Polygon
Пример
В этом примере показано, как можно использовать функцию ST_PolyFromWKB для создания полигона на основе его WKB-представления. В системе пространственной привязки 4326 геометрия представлена полигоном. В этом примере полигон сохраняется с идентификатором ID = 1115 в столбце geometry таблицы sample_polys, затем столбец wkb обновляется с использованием WKB-представления (с помощью функции ST_AsBinary). Наконец, функция ST_PolyFromWKB используется для возврата мультиполигона из столбца wkb. В таблице sample_polys есть столбец geometry, в которой сохраняется полигон, а также столбец wkb, в котором хранится WKB-представление полигона.
В выражении SELECT функция ST_PointFromWKB используется для получения точек из столбца WKB.
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)