下面是 XML 结构。它是我原始结构的一个样本,而不是确切的。
<Docs>
<Doc>
<Para>
<P n="1"><B>Constants : T</B>he value of pi is 3.14</P>
<P n="2">pi is a geometric term.</P>
</Para>
</Doc>
<Doc>
<Para>
<P n="1"><B>Constants : T</B>he value of g is 9.81 m/sqr of sec</P>
<P n="2">g is a acceleration due to gravity.</P>
</Para>
</Doc>
<Doc>
<Para>
<P n="1"><B>Constants : T</B>he value of c is 3.00 x 10 power 8 m/sec</P>
<P n="2">c is a speed of light in vacuum.</P>
</Para>
</Doc>
</Docs>
我以编程方式生成了 XML 文件。该B
节点有数据Constant : T
,它应该只是Constants :
。我编写了一个 XQuery 来进行必要的更改,但它没有按预期工作。
下面是 XQuery - 版本 1
for $x in doc('doc1')//Doc
where $x/Para/P[@n="1"]/B/text()="Constants : T"
return
let $p := $x/Para/P[@n="1"]
let $pText := concat("T", $p/text())
let $tag := <P n="1">{$pText}</P>
return
(
delete node $p,
insert node $tag as first into $x/Para,
insert node <B>Constants :</B> as first into $x/Para/P[@n="1"]
)
版本 - 2(更小、更甜但不起作用!!!)
let $b := <B> Constants :</B>
for $x in doc('doc1')//Doc/Para[P[@n="1"]/B/text()="Constants : T"]/P[@n="1"]
return
(
replace value of node $x with concat("T", $x/text()),
insert node $b/node() as first into $x
)
两个查询都没有插入<B>Constants : </B>
。有人可以帮我吗?