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