1

試験演習中にXMLの「=>」構文を理解するのに問題があります。ウェブで検索しましたが、意味がわかりません。構文が使用されている試験の例を次に示します。

FOR $b IN //Brand
LET $cars :=
    (FOR $c IN //Car
    LET $cb := $c/@model => //Model/..
    WHERE $cb/@name = $b/@name
    RETURN $c)
LET $nr := COUNT($cars)
RETURN <Brand name={$b/@name}>{$nr}</Brand>

目標は、各ブランドのすべての車を数えることです。

これは私の試みでした:

FOR $b IN //Brand
LET $cars := (
   FOR $c IN //Car
   WHERE $c/@Model = $b/Model/@name //Might not work to match against all models this way?
   RETURN ({c})
RETURN <Brand name={$b/@name}>COUNT($cars)</Brand>

そしてこれはXMLドキュメントです:

<!DOCTYPE CarsNStars [
<!ELEMENT CarsNStars (Brand*, Car*)>
<!ELEMENT Brand (Model*)>
<!ELEMENT Model (Year+)>
<!ELEMENT Year (#EMPTY)>
<!ELEMENT Car (#EMPTY)>
<!ATTLIST Brand
   name ID #REQUIRED
   country CDATA #IMPLIED>
<!ATTLIST Model
   name ID #REQUIRED>
<!ATTLIST Year
   year CDATA #REQUIRED
   horsePower CDATA #IMPLIED>
<!ATTLIST Car
   regNr ID #REQUIRED
   model IDREF #REQUIRED
   miles CDATA #REQUIRED>
]>

WHEN to WHEREを編集しましたが、これは明らかに講師からのタイプミスであるに違いありません。

4

1 に答える 1

1

構文=>は、XQuery 仕様 (1.0 または 3.0) のどちらでも定義されていません。どちらでもないWHEN

于 2013-03-14T17:08:36.987 に答える