Определение
ST_PointFromWKB принимает WKB-представление и идентификатор пространственной привязки и возвращает ST_Point.
Синтаксис
Oracle
sde.st_pointfromwkb (wkb blob, srid integer)
sde.st_pointfromwkb (wkb blob)
Если вы не указали SRID, пространственная привязка по умолчанию будет 4326.
PostgreSQL
sde.st_pointfromwkb (wkb bytea, srid integer)
SQLite
st_pointfromwkb (wkb blob, srid int32)
st_pointfromwkb (wkb blob)
Если вы не указали SRID, пространственная привязка по умолчанию будет 4326.
Тип возвращаемого значения
ST_Point
Пример
В этом примере показано, как можно использовать функцию ST_PointFromWKB для создания точки на основе его WKB-представления. В системе пространственной привязки 4326 геометрия представлена точками. В этом примере точки хранятся в столбце geometry таблицы sample_points, затем столбец wkb обновляется с использованием бинарного wkb-представления (с помощью функции ST_AsBinary). Наконец, функция ST_PointFromWKB используется для возврата точек из столбца wkb. В таблице sample-points есть столбец geometry, в котором хранятся точки, а также столбец wkb, в котором хранится WKB-представление точек.
В выражении SELECT функция ST_PointFromWKB используется для получения точек из столбца WKB.
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)