首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对数据集使用跳和联接,如何获得某个属性的最高值。DTL

对数据集使用跳和联接,如何获得某个属性的最高值。DTL
EN

Stack Overflow用户
提问于 2017-12-08 10:11:24
回答 2查看 56关注 0票数 1

我正在对sesam中的数据集运行跳转,我的输出如下所示,我的问题是需要一个join,在这个连接中,我只能获得优先级最高的属性。

代码语言:javascript
复制
[{
    "id": "AAA",
    "priority": 10
  }, {
    "id": "AAB",
    "priority": 7
  }]
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-12-08 12:27:42

您还可以使用"max“函数来解决这个问题:

代码语言:javascript
复制
{
  "_id": "sort-by-prop",
  "type": "pipe",
  "source": {
    "type": "embedded",
    "entities": [{
      "_id": "foo",
      "bar": [{
        "id": "AAA",
        "priority": 10
      }, {
        "id": "AAB",
        "priority": 5
      }]
    }]
  },
  "transform": {
    "type": "dtl",
    "rules": {
      "default": [
        ["copy", "_id"],
        ["add", "foo",
          ["path", "id",
            ["max", "_.priority", "_S.bar"]
          ]
        ]
      ]
    }
  }
}

其结果将是:

代码语言:javascript
复制
[
  {
    "_id": "foo",
    "foo": "AAA"
  }
]
票数 2
EN

Stack Overflow用户

发布于 2017-12-08 10:38:01

您可以使用“排序”、“反向”、“先”和“路径”来解决这个问题:

代码语言:javascript
复制
{
  "_id": "sort-by-prop",
  "type": "pipe",
  "source": {
    "type": "embedded",
    "entities": [{
      "_id": "foo",
      "bar": [{
        "id": "AAA",
        "priority": 10
      }, {
        "id": "AAB",
        "priority": 5
      }]
    }]
  },
  "transform": {
    "type": "dtl",
    "rules": {
      "default": [
        ["copy", "_id"],
        ["add", "foo",
          ["path", "id",
            ["first",
              ["reversed",
                ["sorted", "_.priority", "_S.bar"]
              ]
            ]
          ]
        ]
      ]
    }
  }
}

其结果将是:

代码语言:javascript
复制
[
  {
    "_id": "foo",
    "foo": "AAA"
  }
]
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47712073

复制
相关文章

相似问题

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