微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用 cts:element-attribute-values() 函数获取按元素值排序的数据?

如何解决如何使用 cts:element-attribute-values() 函数获取按元素值排序的数据?

REQUIREMENT :按照加入日期 (/Employee/JoiningDate) 的升序获取查询匹配的员工 ID (/Employee/@id) ) 尽快

环境:MarkLogic DB 拥有100 万 个员工 XML

QUERY-1 [运行速度很慢,但按正确顺序返回数据]

let $fullQuery :=
    cts:and-query((
        cts:directory-query("/employee/","infinity"),cts:element-value-query(fn:QName("","DeptName"),"Sales",("case-insensitive")),"SubDeptName"),"Micro",("case-insensitive"))
    ))
let $queryOptions := ("unfiltered",cts:index-order(cts:element-reference(fn:QName("","JoiningDate"),("type=dateTime")),"ascending"))
return cts:search(/Employee,$fullQuery,$queryOptions)!fn:string(./@id) (: Using ! to get id's in sorted order. This seems to affect performance quite heavily. :)

QUERY-2 [运行速度非常快,但返回的数据顺序不正确]

let $fullQuery :=
    cts:and-query((
        cts:directory-query("/employee/",("case-insensitive"))
    ))
let $queryOptions := ("concurrent")
return cts:element-attribute-values(xs:QName("Employee"),xs:QName("id"),(),$queryOptions,$fullQuery)

如何使用上述两种方法之一来满足要求

解决方法

cts:value-co-occurrences 将让您按一个索引排序,同时从另一个索引返回值。

例如

for $v in cts:value-co-occurrences(
  cts:element-reference(xs:QName("JoiningDate"),cts:element-attribute-reference(xs:QName("Employee"),xs:QName("id")),(),$fullQuery
)
return $v/cts:value[2]/string(.)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?