繁体   English   中英

BaseX中的平均功能变慢

[英]Slow average function in BaseX

我对XML以及XQuery完全陌生。 我有一个很大的XML文件(〜30 GB),已加载到Basex数据库中。 我的问题是平均功能需要很长时间才能运行。

示例XML文件:

<a>
 <b Id="1" Result="1"/>
 <b Id="2" Result="2"/>
 <b Id="1" Result="5"/>
 <b Id="1" Result="510"/>
</a>

我希望Id的平均结果=1。运行时,

for $x in //a/b
where $x/@Id="1"
return $x/@Result

查询大约需要1-2秒。 还不错。 但是,当我尝试获取平均值时,查询永远不会结束(我让它运行了10分钟)

avg(
for $x in //a/b
where $x/@Id="1"
return $x/@Result    
)

到底是怎么回事?

请让我知道我是否可以提供其他有助于答案的信息。

尝试avg(// a / b [@ Id =“ 1”] / @ Result)。 谓词比where子句更有效。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM