ST_PointFromWKB

Definition

Mit ST_PointFromWKB wird anhand eines Well-known Binary-Formats (WKB) und einer Raumbezugs-ID ein ST_Point-Objekt zurückgegeben.

Syntax

Oracle

PostgreSQL

Oracle

sde.st_pointfromwkb (wkb blob, srid integer)

PostgreSQL

sde.st_pointfromwkb (wkb bytea, srid integer)

SQLite

st_pointfromwkb (wkb blob, srid int32)

Rückgabetyp

ST_Point

Beispiel

In diesem Beispiel wird veranschaulicht, wie ST_PointFromWKB zum Erstellen eines Punktes aus einem Well-known Binary-Format verwendet werden kann. Die Geometrien sind Punkte im Raumbezugssystem 4326. In diesem Beispiel werden die Punkte in der Spalte "geometry" der Tabelle "sample_points " gespeichert; anschließend wird die Spalte "wbk" mit dem Well-known Binary-Format (mithilfe der Funktion ST_AsBinary) aktualisiert. Zum Schluss werden die Punkte mithilfe der ST_PointFromWKB-Funktion aus der Spalte "wbk" zurückgegeben. Die Tabelle "sample-points" verfügt über die Spalte "geometry", in der die Punkte gespeichert werden, sowie über die Spalte "wbk", in der das Well-known Binary-Format der Punkte gespeichert wird.

In der SELECT-Anweisung werden die Punkte mit der ST_PointFromWKB-Funktion aus der Spalte "WBK" abgerufen.

Oracle

CREATE TABLE sample_points (
 id integer,
 geometry sde.st_point,
 wkb blob
);

INSERT INTO SAMPLE_POINTS (id, geometry) VALUES (
 10,
 sde.st_point ('point (44 14)', 4326)
);

INSERT INTO SAMPLE_POINTS (id, geometry) VALUES (
 11,
 sde.st_point ('point (24 13)', 4326)
);

UPDATE SAMPLE_POINTS
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 10;

UPDATE SAMPLE_POINTS
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 11;
SELECT id, sde.st_astext (sde.st_pointfromwkb(wkb, 4326)) POINTS
 FROM SAMPLE_POINTS;

ID POINTS

10 POINT (44.00000000 14.00000000) 
11 POINT (24.00000000 13.00000000)

PostgreSQL

CREATE TABLE sample_points (
 id integer,
 geometry sde.st_point,
 wkb bytea
);

INSERT INTO sample_points (id, geometry) VALUES (
 10,
 sde.st_point ('point (44 14)', 4326)
);

INSERT INTO sample_points (id, geometry) VALUES (
 11,
 sde.st_point ('point (24 13)', 4326)
);

UPDATE sample_points
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 10;

UPDATE sample_points
 SET wkb = sde.st_asbinary (geometry)
 WHERE id = 11;
SELECT id, sde.st_astext (sde.st_pointfromwkb(wkb, 4326)) 
 AS points
 FROM sample_points;

id points

10 POINT (44 14) 
11 POINT (24 13)

SQLite

CREATE TABLE sample_pts (
 id integer,
 wkb blob
);

SELECT AddGeometryColumn(
 NULL,
 'sample_pts',
 'geometry',
 4326,
 'point',
 'xy',
 'null'
);

INSERT INTO sample_pts (id, geometry) VALUES (
 10,
 st_point ('point (44 14)', 4326)
);

INSERT INTO sample_pts (id, geometry) VALUES (
 11,
 st_point ('point (24 13)', 4326)
);

UPDATE sample_pts
 SET wkb = st_asbinary (geometry)
 WHERE id = 10;

UPDATE sample_pts
 SET wkb = st_asbinary (geometry)
 WHERE id = 11;
SELECT id, st_astext (st_pointfromwkb(wkb, 4326)) 
 AS "points"
 FROM sample_pts;

id points

10 POINT (44.00000000 14.00000000) 
11 POINT (24.00000000 13.00000000)

Verwandte Themen

5/10/2014