Definición
ST_SymmetricDiff toma dos objetos de geometría y devuelve un objeto de geometría compuesto por las partes de los objetos de origen que no son comunes a ambos.
Sintaxis
Oracle y PostgreSQL
sde.st_symmetricdiff (geometry1 sde.st_geometry, geometry2 sde.st_geometry)
SQLite
st_symmetricdiff (geometry1 geometryblob, geometry2 geometryblob)
Tipo de devolución
Oracle y PostgreSQL
ST_Geometry
SQLite
Geometryblob
Ejemplo
Para un informe especial, el supervisor del condado debe determinar las áreas de cuencas hidrográficas y de radios con columnas de humo peligrosas que no se intersecan.
La tabla watershed contiene una columna de Id., una columna para almacenar el nombre de la cuenca hidrográfica (wname) y una columna de forma que almacena la geometría del área de la cuenca hidrográfica.
La tabla plumes almacena la identidad del sitio en columna Id., mientras que la ubicación geográfica de cada sitio se almacena en la columna de punto de sitio.
La función ST_Buffer genera una zona de influencia que rodea los puntos del sitio de residuos peligrosos. La función ST_SymmetricDiff devuelve los polígonos de las zonas de influencia de los sitios de residuos peligrosos y las cuencas hidrográficas que no se intersecan.
La diferencia simétrica de los sitios de residuos peligrosos y las cuencas hidrográficas da como resultado la sustracción de las áreas intersecadas.
Oracle
CREATE TABLE watershed (
id integer,
wname varchar(40),
shape sde.st_geometry
);
CREATE TABLE plumes (
id integer,
site sde.st_geometry
);
INSERT INTO WATERSHED (ID, WNAME, SHAPE) VALUES (
1,
'Big River',
sde.st_geometry ('polygon ((20 30, 30 30, 30 40, 20 40, 20 30))', 4326)
);
INSERT INTO WATERSHED (ID, WNAME, SHAPE) VALUES (
2,
'Lost Creek',
sde.st_geometry ('polygon ((30 30, 30 50, 50 50, 50 30, 30 30))', 4326)
);
INSERT INTO WATERSHED (ID, WNAME, SHAPE) VALUES (
3,
'Szymborska Stream',
sde.st_geometry ('polygon ((40 40, 40 60, 60 60, 60 40, 40 40))', 4326)
);
INSERT INTO PLUMES (ID, SITE) VALUES (
20,
sde.st_geometry ('point (60 60)', 4326)
);
INSERT INTO PLUMES (ID, SITE) VALUES (
21,
sde.st_geometry ('point (30 30)', 4326)
);
SELECT ws.id WS_ID,
sde.st_area (sde.st_symmetricdiff (sde.st_buffer (p.site, .1), ws.shape)) AREA_NO_INT
FROM PLUMES p, WATERSHED ws
WHERE p.id = 20;
SA_ID AREA_NO_INT
1 100.031393
2 400.031393
3 400.015697
PostgreSQL
CREATE TABLE watershed (
id serial,
wname varchar(40),
shape sde.st_geometry
);
CREATE TABLE plumes (
id serial,
site sde.st_geometry
);
INSERT INTO watershed (wname, shape) VALUES (
'Big River',
sde.st_geometry ('polygon ((20 30, 30 30, 30 40, 20 40, 20 30))', 4326)
);
INSERT INTO watershed (wname, shape) VALUES (
'Lost Creek',
sde.st_geometry ('polygon ((30 30, 30 50, 50 50, 50 30, 30 30))', 4326)
);
INSERT INTO watershed (wname, shape) VALUES (
'Szymborska Stream',
sde.st_geometry ('polygon ((40 40, 40 60, 60 60, 60 40, 40 40))', 4326)
);
INSERT INTO plumes (site) VALUES (
sde.st_geometry ('point (60 60)', 4326)
);
INSERT INTO plumes (site) VALUES (
sde.st_geometry ('point (30 30)', 4326)
);
SELECT ws.id AS WS_ID,
sde.st_area (sde.st_symmetricdiff (sde.st_buffer (p.site, .1), ws.shape)) AS "no intersection"
FROM plumes p, watershed ws
WHERE p.id = 1;
ws_id no intersection
1 100.031393502001
2 400.031393502001
3 400.01569751
SQLite
CREATE TABLE watershed (
id integer primary key autoincrement not null,
wname text(40)
);
SELECT AddGeometryColumn(
NULL,
'watershed',
'shape',
4326,
'polygon',
'xy',
'null'
);
CREATE TABLE plumes (
id integer primary key autoincrement not null
);
SELECT AddGeometryColumn(
NULL,
'plumes',
'site',
4326,
'point',
'xy',
'null'
);
INSERT INTO watershed (wname, shape) VALUES (
'Big River',
st_geometry ('polygon ((20 30, 30 30, 30 40, 20 40, 20 30))', 4326)
);
INSERT INTO watershed (wname, shape) VALUES (
'Lost Creek',
st_geometry ('polygon ((30 30, 30 50, 50 50, 50 30, 30 30))', 4326)
);
INSERT INTO watershed (wname, shape) VALUES (
'Szymborska Stream',
st_geometry ('polygon ((40 40, 40 60, 60 60, 60 40, 40 40))', 4326)
);
INSERT INTO plumes (site) VALUES (
st_geometry ('point (60 60)', 4326)
);
INSERT INTO plumes (site) VALUES (
st_geometry ('point (30 30)', 4326)
);
SELECT ws.id AS WS_ID,
st_area (st_symmetricdiff (st_buffer (p.site, .1), ws.shape)) AS "no intersection"
FROM plumes p, watershed ws
WHERE p.id = 1;
WS_ID no intersection
1 400.031393502001
2 100.031393502001
3 400.01569751