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
sde.st_pointfromwkb (wkb blob, srid integer)
PostgreSQL
sde.st_pointfromwkb (wkb bytea, srid integer)
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 1. 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.
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)', 0) ); INSERT INTO SAMPLE_POINTS (id, geometry) VALUES ( 11, sde.st_point ('point (24 13)', 0) ); UPDATE SAMPLE_POINTS SET wkb = sde.st_asbinary (geometry) WHERE id = 10; UPDATE SAMPLE_POINTS SET wkb = sde.st_asbinary (geometry) WHERE id = 11;
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)', 0) ); INSERT INTO sample_points (id, geometry) VALUES ( 11, sde.st_point ('point (24 13)', 0) ); UPDATE sample_points SET wkb = sde.st_asbinary (geometry) WHERE id = 10; UPDATE sample_points SET wkb = sde.st_asbinary (geometry) WHERE id = 11;
In der folgenden SELECT-Anweisung werden die Punkte mit der ST_PointFromWKB-Funktion aus der Spalte "WBK" abgerufen.
Oracle
SELECT id, sde.st_astext (sde.st_pointfromwkb(wkb, 0)) POINTS FROM SAMPLE_POINTS; ID POINTS 10 POINT (44.00000000 14.00000000) 11 POINT (24.00000000 13.00000000)
PostgreSQL
SELECT id, sde.st_astext (sde.st_pointfromwkb(wkb, 0)) AS points FROM sample_points; id points 10 POINT (44 14) 11 POINT (24 13)