Zadani
(pocty bodu za kazdou otazku jsou uvedeny v hranatych zavorkach za znenim otazky)
<b>1.</b> Oznacte spravne odpovedi. [1] :(a) XPath 2.0 je podmnozinou XQuery 1.0
:(b) XPath sdili jen cast vyrazovych prostredku s XQuery :(c) XQuery umoznuje uzivateli deklarovat funkce
:(d) XQuery bylo mineno jako nahrada XSLT
<b>2.</b> Jmenujte alespon 4 prvky jazyka XML schema, ktere umoznuji propojit XML schema s jinym XML schematem. [2]
<b>3.</b> Uvazujte schema podobne jako je na obrazku 1 a popiste slovne vyznam nasledujicich XPath vyrazu. Pro usnadneni nepouzivejte terminy jako uzel ci element, ale spise khiha, nadpis atd. [4] :(a) //kniha/nadpis
:(b) //kniha/*/sekce[2] :(c) kapitola[nadpis]
<b>4.</b> Zaskrtnete to, co je v soulady s pravidly XSLT. [1]
:(a) <xsl:template match = "ahoj" >
akce </xsl:template>
:(b)
<xsl:template if test="podminka"> akce else jina akce </xsl:template>
:(c) <xsl:template when test="podminka">
akce </xsl:template>
<b>5.</b> Pro dany XML dokument nakreslete strom a demonstrujte ohodnoceni jeho uzlu podle algoritmu structure-centered mapping. Vysvetlete vyhody a nevyhody tohoto algoritmu. [3]
<osoba>
<jmeno>
<krestni>Karel</krestni>
<prijmeni>Nemec</prijmeni>
</jmeno>
<email>karel.nemec@comp.cz</email>
</osoba>
<b>6.</b> Element <kniha> neni korenovy element, ale pouze soucast nejake hierarchicke struktury dokumentu "kniha.xml". Kazda kniha ma pouze jednoho autora, atribut email u elementu autor je nepovinny. Aktualni kontextovy uzel je rodic elementu kniha, ktery je zobrazen na obrazku 1.
image:Prg036_pisemka_2007-06-05-kniha.png
Napise XPath dotaz:
D1. Predchazejici uzly pred nadpisem 1.kapitoly elementu kniha. Vysledek vyznacte take v obrazku. [2]
<b>7.</b> D2. Napiste dotaz v jazyce XQuery ktery vrati pro kazdeho autora jeho jmeno v elementu <jmeno>, jeho email v elementu <email>. Tyto udaje se ve vysledku budou nachazet v elementu <autor> a cely vysledek bude vlozen v elementu <autori>. [3]
<b>8.</b> D3. Uvazujte stejny dotaz v XQuery jako v D2 pouze s tim rozdilem, ze pokud autor nema email pak v elementu <email> uvedte text "Nema emailovou adresu". [3]
Spravne odpovedi
Tyto odpovedi byly uznany v pisemce jako spravne:
<b>1.</b> Spravne je (a) a (c).
<b>2.</b> 4 pozadovane prvky jsou napr. include, import, redefine, any.
<b>3.</b>
:: (a) kazdy nadpis kazde kapitoly, avsak pouze takovy nadpis, ktery je primym synem kapitoly :: (b) kazda druha sekce takova, ze jako prarodice ma element kniha :: (c) kapitola, ktera ma nadpis. Zde je vsak potreba zminit, ze zalezi na aktualnim kontextkovem uzlu, ve kterem se prave nachazime.
<b>4.</b> Spravne je pouze (a).
<b>5.</b> (Odpoved lze najit ve slidech s nazvem "Vztah XML databází k jiným databázovým systémům")
:: Vyhody: Pro kazde dva elementy lze urcit jejich vzajemny vztah - jestli jeden je podelementem druheho ci naopak. :: Nevyhody: Fakticky nelze snadno aktualizovat. Pri aktualizaci je zapotrebi cely strom precislovat. :: Strom je zobrazen na nasledujicim obrazku. Ohodnoceni uzlu je dvojice hodnot, kde ta prvni odpovida preorder pruchodu stromem a druha postorder pruchodu.
Image:XML-05-06-2007-osoba.png
<b>6.</b> kniha/kapitola[1]/nadpis/preceding::* Image:Prg036_pisemka_2007-06-05-kniha2.png
<b>7.</b>
<autori>
{
for $kniha = doc("kniha.xml")//kniha
return
<autor>
<jmeno>{ $kniha/autor/text() }</jmeno>
<email>{ $kniha/@email }</email>
</autor>
}
</autori>
<b>8.</b>
<autori>
{
for $kniha = doc("kniha.xml")//kniha
let $email := $kniha/@email
return
<autor>
<jmeno>{ $kniha/autor/text() }</jmeno>
{
if (exists($email))
then <email>{ $email }</email>
else <email>Nema emailovou adresu</email>
}
</autor>
}
</autori>
Bodovani
Celkem bylo mozne ziskat 21 bodu, znamkovaci stupnice byla nasledujici:
:: 19 - 21 → 1 :: 18 - 17 → 2 :: 16 - 15 → 3 :: jinak za 4