ST_PolyFromWKB
Определение
ST_PolyFromWKB принимает WKB-представление и идентификатор пространственной привязки и возвращает ST_Polygon.
Синтаксис
Oracle
sde.st_polyfromwkb (wkb blob, srid integer)
PostgreSQL
sde.st_polyfromwkb (wkb bytea, srid integer)
Тип возврата
ST_Polygon
Пример
В следующем примере строки результаты были отформатированы для улучшения восприятия. Отступы в результатах будут зависеть от отображения на экране. В этом примере показано, как можно использовать функцию ST_PolyFromWKB для создания полигона на основе его WKB-представления. Геометрия – полигон в системе пространственной привязки 1. В этом примере полигон сохраняется с идентификатором = 1115 в столбце geometry таблицы sample_polys, затем столбец wkb обновляется с использованием WKB-представления (с помощью функции ST_AsBinary). Наконец, функция ST_PolyFromWKB используется для возврата мультиполигона из столбца wkb. Координаты x и y в этой геометрии: (50, 20) (50, 40) (70, 30). В таблице sample_polys есть столбец geometry, в которой сохраняется полигон, а также столбец wkb, в котором хранится 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))', 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;
В следующем выражении SELECT функция ST_PointFromWKB используется для получения точек из столбца wkb.
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)