27.06.2015 Views

Modelování geoprostorové báze dat na úrovni datového modelu KN

Modelování geoprostorové báze dat na úrovni datového modelu KN

Modelování geoprostorové báze dat na úrovni datového modelu KN

SHOW MORE
SHOW LESS

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

Modelování geoprostorové báze <strong>dat</strong> <strong>na</strong> úrovni <strong>dat</strong>ového <strong>modelu</strong> <strong>KN</strong><br />

programu jsem <strong>na</strong>razil <strong>na</strong> skutečnost, že v <strong>dat</strong>ech získaných<br />

z výměnného formátu může mít hraniční úsek z tabulky<br />

HRANICE_PARCEL uložený pod jednoz<strong>na</strong>čným identifikátorem shodný<br />

počáteční a koncový bod. Tuto variantu jsem v programu patřičně<br />

ošetřil a učinil tak program RELtoOO.exe plně funkčním. Zdrojový kód<br />

programu RELtoOO.exe v jazyce PASCAL lze <strong>na</strong>lézt <strong>na</strong> přiloženém CD<br />

k této diplomové práci v souboru RELtoOO.pas.<br />

4.7 Import <strong>dat</strong> do tabulky KATASTRALNI_HRANICE<br />

K importu <strong>dat</strong> to tabulky KATASTRALNI_HRANICE jsem použil<br />

<strong>dat</strong>abázového klienta TOAD. Vzhledem k formátu souboru RELtoOO.sql<br />

bylo možné tento soubor v klientu s<strong>na</strong>dno otevřít a nechat vyko<strong>na</strong>t<br />

uložený příkaz INSERT. Tímto způsobem jsem se s<strong>na</strong>žil vložit <strong>dat</strong>a pro<br />

každý nový záz<strong>na</strong>m.<br />

Při importu <strong>dat</strong> ze souboru RELtoOO.sql, který v tu chvíli<br />

obsahoval <strong>dat</strong>a o průběhu hranice katastrálního území Týnec u Janovic<br />

<strong>na</strong>d Úhlavou, oznámil <strong>dat</strong>abázový klient chybu, že vstupní <strong>dat</strong>a obsahují<br />

příliš mnoho argumentů. Katastrální území Týnec u Janovic <strong>na</strong>d Úhlavou<br />

bylo nejrozsáhlejším územím v <strong>dat</strong>ech, která jsem měl pro účely<br />

diplomové práce k dispozici. Pokusil jsem se příčinu oznámení chyby<br />

<strong>na</strong>lézt v [11]. Ukázalo se, že Spatial neumí pomocí standardního<br />

příkazu INSERT vložit do atributu typu SDO_GEOMETRY pole<br />

sdo_ordi<strong>na</strong>tes, které obsahuje více jak 999 souřadnic bodů. Tento<br />

problém se nechá řešit dvěma způsoby:<br />

1) Využití programovacího jazyka PL/SQL.<br />

2) Využití metody importu zvané „BULK LOADING“.<br />

4.7.1 Import <strong>dat</strong> s využitím PL/SQL<br />

Při řešení problému s importem rozsáhlejší množiny <strong>dat</strong> jsem využil<br />

právě možností programovacího jazyka PL/SQL. Obecně se nechá řešení<br />

s využitím jazyka PL/SQL <strong>na</strong> vložení takovéto množiny <strong>dat</strong> popsat<br />

následujícím způsobem:<br />

• Definování procedury, která vloží do příslušné tabulky, v mém<br />

případě tabulky KATASTRALNI_HRANICE, potřebná <strong>dat</strong>a včetně<br />

proměnné typu SDO_GEOMETRY s přiřazeným geometrickým<br />

popisem katastrální hranice, přičemž tento popis může obsahovat<br />

více jak 999 souřadnic bodů. Horní limit <strong>na</strong> omezení počtu<br />

souřadnic vkládaných v poli sdo_ordi<strong>na</strong>tes jsem se z žádných<br />

dostupných zdrojů nedozvěděl.<br />

50

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!