使用格式对日期字段进行排序不起作用

时间:2019-05-08 09:20:14

标签: node.js elasticsearch

我正在将ElasticSearch 7.0与ES NodeJS一起使用。我用日期和格式类型映射了该字段。我试图用date desc排序,最新的对象放在索引3而不是第一个。

映射

[http]
proxy = http://username:password@host:port

[https]
proxy = http://username:password@host:port

搜索排序

client.indices.putMapping({
  index: 'property',
  body: {
    properties: {
      'created_at': { 
        'type': 'date', 
        "format":"YYYY-MM-DD'T'HH:mm:ss.000'Z'", 
        "ignore_malformed": true 
      }
    }
  }
})

结果

client.search({
    index: 'property',
    body: {
      from : req.body.start,
      size : req.body.length,
      query : {
        "bool": {
          "must": []
        }
      },
      sort: [
        { 'created_at': { 'order': 'desc' }}
      ]
    }
})

预期结果

[
  { "created_at": "2019-05-03T17:19:59.000Z" },
  { "created_at": "2019-05-03T17:06:26.000Z" },
  { "created_at": "2019-05-08T16:00:34.000Z" }
]

0 个答案:

没有答案