如何对嵌套字段进行排序?

问题描述

下面的数据是弹性搜索索引的搜索查询输出。我想根据review.rate字段对数据进行排序。

我该怎么办?

数据

[{
    "name": "ABC","review": [{
        'rate': 1.5,'note': "XYZ",'type': "review"
    },{
        'rate': 4.5,'type': "note"
    },{
        'rate': 2.0,'type': "comment"
    }]
},{
    "name": "PQR","review": [{
        'rate': "",'type': "comment"
    },{
        'rate': 3.5,{
        'rate': 1.0,'type': "review"
    }]
},{
    "name": "STU","review": [{
        'rate': 5.0,'type': "comment" 
    },{
        'rate': 1.5,'type': "note"
    }]
}]

尝试了以下内容

查询

{
    "_source": {
        "includes": [
            "name"
        ]
    },"query":{
        "bool": [{
          "nested": {
            "path": "review","query": {
              "bool": {
                "must": [
                  {
                    "term": {
                      "review.type": "comment"
                    }
                  }
                ]
              }
            }
          }
        }]
    },"sort": ["review.rate"]
}

输出必须为[PQR,ABC,STU]。我该如何实现?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...