ST_MPolyFromWKB
Definición
ST_MPointFromWKB toma una representación binaria conocida (WKB) de tipo ST_MultiPolygon y un Id. de referencia espacial para devolver una ST_MultiPolygon.
Sintaxis
Oracle
sde.st_mpolyfromwkb (wkb blob, srid integer)
PostgreSQL
sde.st_mpolyfromwkb (wkb bytea, srid integer)
Tipo de devolución
ST_MultiPolygon
Ejemplo
En el siguiente ejemplo, las líneas de los resultados se han reformateado para su legibilidad. El espaciado en sus resultados variará según su visualización en línea. En este ejemplo se muestra cómo se puede utilizar ST_MPolyFromWKB para crear un multipolígono desde su representación binaria conocida. La geometría es un multipolígono en el sistema de referencia espacial 1. En este ejemplo, el multipolígono se almacena con Id. = 10 en la columna de geometría de la tabla sample_mpolys, entonces la columna wkb se actualiza con su representación binaria conocida (utilizando la función ST_AsBinary). Por último, la función ST_MPolyFromWKB se utiliza para devolver el multipolígono desde la columna wkb. Las coordenadas x e y para esta geometría son polígono v 1: (1), 72 (4), 79 (5), 76 (1, 72); polígono v 2: (10, 20) (10, 40) (30, 41) (10, 20); y polígono v 3: (9, 43) (7, 44) (6, 47) (9, 43). La tabla sample_mpolys tiene una columna de geometría, donde se almacena el multipolígono, y una columna wkb, donde la representación WKB de un multipolígono está almacenada.
Oracle
CREATE TABLE sample_mpolys (id integer, geometry sde.st_geometry, wkb blob); INSERT INTO SAMPLE_MPOLYS VALUES ( 10, sde.st_multipolygon ('multipolygon (((1 72, 4 79, 5 76, 1 72), (10 20, 10 40, 30 41, 10 20), (9 43, 7 44, 6 47, 9 43)))', 0) ); UPDATE SAMPLE_MPOLYS SET wkb = sde.st_asbinary (geometry) WHERE id = 10;
PostgreSQL
CREATE TABLE sample_mpolys (id integer, geometry sde.st_geometry, wkb bytea); INSERT INTO sample_mpolys VALUES ( 10, sde.st_multipolygon ('multipolygon (((1 72, 4 79, 5 76, 1 72), (10 20, 10 40, 30 41, 10 20), (9 43, 7 44, 6 47, 9 43)))', 0) ); UPDATE sample_mpolys SET wkb = sde.st_asbinary (geometry) WHERE id = 10;
En la siguiente declaración SELECT, la función ST_MPointFromWKB se usa para recuperar el multipolígono desde la columna WKB.
Oracle
SELECT id, sde.st_astext (sde.st_mpolyfromwkb (wkb,0)) MULTIPOLYGON FROM SAMPLE_MPOLYS WHERE id = 10; ID MULTIPOLYGON 10 MULTIPOLYGON (((10.00000000 20.00000000, 30.00000000 41.00000000, 10.00000000 40.00000000, 10.00000000 20.00000000)), (1.00000000 72.00000000, 5.00000000 76.00000000, 4.00000000 79.0000000, 1.00000000 72,00000000)), (9.00000000 43.00000000, 6.00000000 47.00000000, 7.00000000 44.00000000, 9.00000000 43.00000000 )))
PostgreSQL
SELECT id, sde.st_astext (sde.st_mpolyfromwkb (wkb,0)) AS MULTIPOLYGON FROM sample_mpolys WHERE id = 10; id multipolygon 10 MULTIPOLYGON (((10 20, 30 41, 10 40, 10 20)), (1. 72, 5 76, 4 79, 1 72)), (9 43, 6 47, 7 44, 9 43 )))