Ukázka prostorových operací

From Wikivyuka
Revision as of 06:20, 15 April 2014 by Dur30 (talk | contribs)

Jump to: navigation, search

Použití jednotlivých operátorů v dotazech SQL, kde jsou předvedeny různé topologické vztahy:

SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_ANYINTERACT(l.geom, n.geom) = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';
SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_CONTAINS(n.geom, l.geom) = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';
SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_COVERS(n.geom, l.geom) = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';

Užití SDO_COVEREDBY

SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_COVEREDBY(L.geom, N.geom) = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';

Dotaz lze formulovat i pomocí operátoru SDO_RELATE

 SDO_RELATE(geometry1,geometry2, 'mask = <some_mask_val>') = 'TRUE' 

kde je do parametru mask doplněn požadovaný typ vztahu:

SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_RELATE(l.geom, n.geom, 'mask = COVEREDBY') = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';
SELECT l.naz_lau1, l.geom
FROM okresy l, kraje n
WHERE SDO_TOUCH(n.geom, l.geom) = 'TRUE' AND l.naz_cnuts2 = 'Moravskoslezsko';