假设我有以下SQL查询要处理
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索引?根据文档,这听起来可能有助于过滤节点,但我还没有遇到任何处理这样的查询的例子。
发布于 2018-02-26 07:59:40
选择性XML索引支持由Server在exist()、value()和XQuery ()方法中支持的XML。
不支持query(),所以它不适合您。
另一方面,它说
对于查询()和修改()方法,选择性XML索引仅可用于节点筛选。
我无法使用query()方法生成使用XML索引的查询,因此我无法真正告诉您在什么情况下可以工作。
如果您想解决查询的性能问题,我建议您使用nodes()和value()分解XML,然后使用for xml path重新构造XML。它通常比用query()构建XML更快,如果需要的话,您也可以使用选择性的XML索引。
https://dba.stackexchange.com/questions/198381
复制相似问题