首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >当使用query()时,选择性的XML索引会有帮助吗?

当使用query()时,选择性的XML索引会有帮助吗?
EN

Database Administration用户
提问于 2018-02-20 17:29:01
回答 1查看 168关注 0票数 2

假设我有以下SQL查询要处理

代码语言:javascript
复制
Select
myxml.query(
'

{for $each in /This/Company/Department[1]/Role/Person
return if ($each/Shoes/F[@C="9"]="657493742")
then ({$each/Shoes/F[@C="9916"]/V})
else ()}
')
FROM mytable

是否有一种方法可以在这种情况下创建有选择的XML索引?根据文档,这听起来可能有助于过滤节点,但我还没有遇到任何处理这样的查询的例子。

EN

回答 1

Database Administration用户

发布于 2018-02-26 07:59:40

来自选择性XML索引(SXI)、支持的特性、先决条件和限制

选择性XML索引支持由Server在exist()、value()和XQuery ()方法中支持的XML。

不支持query(),所以它不适合您。

另一方面,它说

对于查询()和修改()方法,选择性XML索引仅可用于节点筛选。

我无法使用query()方法生成使用XML索引的查询,因此我无法真正告诉您在什么情况下可以工作。

如果您想解决查询的性能问题,我建议您使用nodes()value()分解XML,然后使用for xml path重新构造XML。它通常比用query()构建XML更快,如果需要的话,您也可以使用选择性的XML索引。

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/198381

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档