Определение
ST_PointOnSurface принимает ST_Polygon или ST_MultiPolygon и возвращает ST_Point, которая гарантированно лежит на поверхности входного объекта.
Синтаксис
Oracle и PostgreSQL
sde.st_pointonsurface (polygon1 sde.st_geometry) sde.st_pointonsurface (multipolygon1 sde.st_geometry)
SQLite
st_pointonsurface (polygon1 geometryblob) st_pointonsurface (multipolygon1 geometryblob)
Возвращаемый тип
ST_Point
Пример:
Городской инженер хочет создать точку метки для каждого контура исторического здания. Контуры исторических зданий хранятся в таблице buildings, созданной с помощью следующей инструкции CREATE TABLE:
Функция ST_PointOnSurface создает точку, которая гарантированно будет располагаться на поверхности контуров зданий. Функция ST_PointOnSurface возвращает точку, которую функция ST_AsText преобразует в текстовое представление, поддерживаемое приложением.
Oracle
CREATE TABLE hbuildings (
hbld_id integer,
hbld_name varchar(40),
footprint sde.st_geometry
);
INSERT INTO hbuildings (hbld_id, hbld_name, footprint) VALUES (
1,
'First National Bank',
sde.st_polygon ('polygon ((0 0, 0 .010, .010 .010, .010 0, 0 0))', 4326)
);
INSERT INTO hbuildings (hbld_id, hbld_name, footprint) VALUES (
2,
'Courthouse',
sde.st_polygon ('polygon ((.020 0, .020 .010, .030 .010, .030 0, .020 0))', 4326)
);
SELECT sde.st_astext (sde.st_pointonsurface (footprint)) Historic_Site
FROM HBUILDINGS;
HISTORIC_SITE
POINT (0.00500000 0.00500000)
POINT (0.02500000 0.00500000)
PostgreSQL
CREATE TABLE hbuildings (
hbld_id serial,
hbld_name varchar(40),
footprint sde.st_geometry
);
INSERT INTO hbuildings (hbld_name, footprint) VALUES (
'First National Bank',
sde.st_polygon ('polygon ((0 0, 0 .010, .010 .010, .010 0, 0 0))', 4326)
);
INSERT INTO hbuildings (hbld_name, footprint) VALUES (
'Courthouse',
sde.st_polygon ('polygon ((.020 0, .020 .010, .030 .010, .030 0, .020 0))', 4326)
);
SELECT sde.st_astext (sde.st_pointonsurface (footprint))
AS "Historic Site"
FROM hbuildings;
Historic Site
POINT (0.00500000 0.00500000)
POINT (0.02500000 0.00500000)
SQLite
CREATE TABLE hbuildings (
hbld_id integer primary key autoincrement not null,
hbld_name text(40)
);
SELECT AddGeometryColumn(
NULL,
'hbuildings',
'footprint',
4326,
'polygon',
'xy',
'null'
);
INSERT INTO hbuildings (hbld_name, footprint) VALUES (
'First National Bank',
st_polygon ('polygon ((0 0, 0 .010, .010 .010, .010 0, 0 0))', 4326)
);
INSERT INTO hbuildings (hbld_name, footprint) VALUES (
'Courthouse',
st_polygon ('polygon ((.020 0, .020 .010, .030 .010, .030 0, .020 0))', 4326)
);
SELECT st_astext (st_pointonsurface (footprint))
AS "Historic Site"
FROM hbuildings;
Historic Site
POINT (0.00500000 0.00500000)
POINT (0.02500000 0.00500000)