ST_MPointFromWKB

定義

ST_MPointFromText は、ST_MultiPoint タイプの WKB 表現と空間参照 ID を受け取って、ST_MultiPoint を作成します。

構文

Oracle

sde.st_mpointfromwkb (wkb blob, srid integer)

PostgreSQL

sde.st_mpointfromwkb (wkb bytea, srid integer)

SQLite

st_mpointfromwkb (wkb blob, srid int32)

戻り値のタイプ

ST_MultiPoint

この例では、ST_MPointFromWKB を使用して、その WKB 表現からマルチポイントを作成する方法を示しています。ジオメトリは、空間参照系 4326 のマルチポイントです。この例では、マルチポイントを SAMPLE_MPOINTS テーブルの GEOMETRY 列に ID = 10 で格納した後、WKB 列を(ST_AsBinary 関数を使用して)WKB 表現で更新しています。最後に、ST_MPointFromWKB 関数を使用して、WKB 列からマルチポイントを返します。SAMPLE_MPOINTS テーブルには、マルチポイントを格納する GEOMETRY 列と、マルチポイントの WKB 表現を格納する WKB 列があります。

次の SELECT ステートメントで、ST_MPointFromWKB 関数を使用して、WKB 列からマルチポイントを取得します。

Oracle

CREATE TABLE sample_mpoints (
 id integer,
 geometry sde.st_geometry,
 wkb blob
);
INSERT INTO SAMPLE_MPOINTS (id, geometry) VALUES (
 10,
 sde.st_multipoint ('multipoint (4 14, 35 16, 24 13)', 4326)
);
UPDATE SAMPLE_MPOINTS
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 10;
SELECT id, sde.st_astext (sde.st_mpointfromwkb (wkb,4326)) MULTI_POINT
 FROM SAMPLE_MPOINTS
 WHERE id = 10;
ID 	  MULTI_POINT 
10    MULTIPOINT (4.00000000 14.00000000, 35.00000000 16.00000000 24.00000000 13.00000000)

PostgreSQL

CREATE TABLE sample_mpoints (
 id integer,
 geometry sde.st_geometry,
 wkb bytea
);
INSERT INTO sample_mpoints (id, geometry) VALUES (
 10,
 sde.st_multipoint ('multipoint (4 14, 35 16, 24 13)', 4326)
);
UPDATE sample_mpoints
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 10;
SELECT id, sde.st_astext (sde.st_mpointfromwkb (wkb,4326)) 
 AS "MULTI_POINT"
 FROM sample_mpoints
 WHERE id = 10;
id 	  MULTI_POINT 
10     MULTIPOINT (4 14, 35 16, 24 13)

SQLite

CREATE TABLE sample_mpoints (
 id integer,
 wkb blob
);
SELECT AddGeometryColumn (
 NULL,
 'sample_mpoints',
 'geometry',
 4326,
 'multipointzm',
 'xyzm',
 'null'
);
INSERT INTO SAMPLE_MPOINTS (id, geometry) VALUES (
 10,
 st_multipoint ('multipoint (4 14, 35 16, 24 13)', 4326)
);
UPDATE sample_mpoints
 SET wkb = st_asbinary (geometry)
 WHERE id = 10;
SELECT id AS "ID",
 st_astext (st_mpointfromwkb (wkb,4326)) 
 AS "MULTI_POINT"
 FROM sample_mpoints
 WHERE id = 10;
ID 	  MULTI_POINT 
10    MULTIPOINT ( 4.00000000 14.00000000, 35.00000000 16.00000000, 24.00000000 13.00000000)

関連トピック

5/25/2014