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

How to get data sorted on an element's values using cts:element-attribute-values() function?

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

ENVIRONMENT:MarkLogic DB 有 100 万 名员工 XML

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

let $fullQuery :=
    cts:and-query((
        cts:directory-query("/employee/", "infinity"),
        cts:element-value-query(fn:QName("","DeptName"), "Sales", ("case-insensitive")),
        cts:element-value-query(fn:QName("","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 [运行速度非常快,但 returns 数据顺序不正确]

let $fullQuery :=
    cts:and-query((
        cts:directory-query("/employee/", "infinity"),
        cts:element-value-query(fn:QName("","DeptName"), "Sales", ("case-insensitive")),
        cts:element-value-query(fn:QName("","SubDeptName"), "Micro", ("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(.)