序列中的每个数据项目可能彼此非常相似,或者它们可能是不同的类型。
我们从一些简单的序列示例开始。看一下最常见的序列运算符。 XQuery使用单词sequence作为有序容器容器的通用名称。
了解序列在XQuery中的工作方式对于理解语言的工作原理至关重要。 通用项目序列的使用是函数式编程的核心,与其他编程语言(如Java或JavaScript)形成鲜明对比,后者提供了多种方法和函数来处理键值对,字典,数组和XML数据。 XQuery的精彩之处在于,您只需要学习一组概念和一小部分函数来学习如何快速操作数据。
创建字符和字符串序列
可以使用括号来包含序列,使用逗号分隔数据项目和引号以包含字符串值:
let $sequence := ('a', 'b', 'c', 'd', 'e', 'f')
请注意,可以使用单引号或双引号,但对于大多数字符串,使用单引号。
let $sequence := (apple, 'banana', carrot, 'dog', egg, 'fig')
还可以混合数据类型。 例如,以下序列在同一序列中具有三个字符串和三个整数。
let $sequence := ('a', 'b', 'c', 1, 2, 3)
然后,可以将序列传递给任何适用于序列的XQuery函数。 例如,count()函数将序列作为输入,并返回序列中的数据项数量。
let $count := count($sequence)
查看序列中的数据项
let $sequence := ('a', 'b', 'c', 'd', 'e', 'f')
let $count := count($sequence)
return
<results>
<count>{$count}</count>
<items>
{for $item in $sequence
return
<item>{$item}</item>
}
</items>
</results>
执行结果如下所示 –
<results>
<count>6</count>
<items>
<item>a</item>
<item>b</item>
<item>c</item>
<item>d</item>
<item>e</item>
<item>f</item>
</items>
</results>
查看序列中的选定数据项目
可以使用谓词表达式选择序列中的数据项目。可以按位置选择项目(从1开始):
let $sequence := ('a', 'b', 'c', 'd', 'e', 'f')
return
<items>{
for $item in $sequence[1, 3, 4]
return
<item>{$item}</item>
}
</items>
结果如下所示 –
<items>
<item>a</item>
<item>c</item>
<item>d</item>
</items>
或按值:
let $sequence := ('a', 'b', 'c', 'd', 'e', 'f')
return
<items>{
for $item in $sequence[. = ('a','e')]
return
<item>{$item}</item>
}
</items>
结果如下所示 –
<items>
<item>a</item>
<item>e</item>
</items>
将XML元素添加到序列中
还可以按顺序存储XML元素。
let $sequence := ('apple', <banana/>, <fruit type=carrot/>, <animal type='dog'/>, <vehicle>car</vehicle>)
虽然可以使用括号来创建一系列XML项,但最佳实践是使用XML标记来开始和结束序列并将所有项存储为XML元素。建议使用项目作为元素名称来保存数据项目的通用序列。
下面是一个例子:
let $items :=
<items>
<banana/>
<fruit type=carrot/>
<animal type='dog'/>
<vehicle>car</vehicle>
</items>
另一个约定是将所有单个项目放在它们自己的item元素标记中,并在项目列表变长时将每个项目放在单独的行上。
let $items :=
<items>
<item>banana</item>
<item>
<fruit type=carrot/>
</item>
<item>
<animal type='dog'/>
</item>
<item>
<vehicle>car</vehicle>
</item>
</items>
然后可以使用以下FLWOR表达式来显示以下每个数据项目:
let $sequence :=
<items>
<item>banana</item>
<item>
<fruit type=carrot/>
</item>
<item>
<animal type='dog'/>
</item>
<item>
<vehicle>car</vehicle>
</item>
</items>
return
<results>{
for $item in $sequence/item
return
<item>{$item}</item>
}</results>
它将返回以下XML内容 –
<results>
<item>
<item>banana</item>
</item>
<item>
<item>
<fruit type=carrot/>
</item>
</item>
<item>
<item>
<animal type=dog/>
</item>
</item>
<item>
<item>
<vehicle>car</vehicle>
</item>
</item>
</results>