Definition
Mit "ST_MPointFromText" wird anhand einer Repräsentation im WKB-Format (Well-Known Binary) vom Typ "ST_MultiPoint" und einer Raumbezugs-ID ein ST_MultiPoint-Objekt erstellt.
Syntax
Oracle
sde.st_mpointfromwkb (wkb blob, srid integer)
sde.st_mpointfromwkb (wkb blob)
Wenn Sie keine SRID angeben, ist der standardmäßige Raumbezug 4326.
PostgreSQL
sde.st_mpointfromwkb (wkb bytea, srid integer)
SQLite
st_mpointfromwkb (wkb blob, srid int32)
st_mpointfromwkb (wkb blob)
Wenn Sie keine SRID angeben, ist der standardmäßige Raumbezug 4326.
Rückgabetyp
ST_MultiPoint
Beispiel
In diesem Beispiel wird veranschaulicht, wie ST_MPointFromWKB zum Erstellen eines Multipoints aus seiner WKB-Repräsentation (Well-Known Binary) verwendet werden kann. Bei der Geometrie handelt es sich um einen Multipoint im Raumbezugssystem 4326. In diesem Beispiel wird der Multipoint mit der ID = 10 in der Spalte "GEOMETRY" der Tabelle "SAMPLE_MPOINTS" gespeichert. Anschließend wird die Spalte "WKB" mit der Repräsentation im WKB-Format (Well-Known Binary) (mithilfe der Funktion "ST_AsBinary") aktualisiert. Zum Schluss wird mit der ST_MPointFromWKB-Funktion der Multipoint aus der Spalte "WBK" zurückgegeben. Die Tabelle "SAMPLE_MPOINTS" verfügt über die Spalte "GEOMETRY", in der der Multipoint gespeichert wird, sowie über die Spalte "WBK", in der die Repräsentation im WKB-Format (Well-Known Binary) des Multipoints gespeichert wird.
In der folgenden SELECT-Anweisung wird mit der ST_MPointFromWKB-Funktion der Multipoint aus der Spalte "WBK" abgerufen.
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)