弹性搜索 PHP 客户端日期范围查询


Elastic Search PHP Client Date Range Query

我有这段代码来执行查询。我正在使用官方的 php 弹性搜索库。https://github.com/elastic/elasticsearch-php

字段 "Tijdsperiode" 采用以下格式: ( 2016-01-30 00:00:00 ) ( YY-MM-DD HH:MM:SS )

  $params = [
    'index' => 'veenendaal2',
    'type' => 'passanten2',
    'body' => [
      'query' => [
        'match_all' => [],
        'filter' => [
          'range' => [
            'Tijdsperiode' => [
              'gte' => '2016-01-30 01:00:00',
              'lte' => '2016-01-30 08:00:00'
            ]
          ]
        ]
      ],
    ],
  ];
  $response = $client->search($params);
  var_dump($response);

我只是想知道需要什么格式才能在 2 个日期之间获得结果。

当我这样做时:

 $params = [
    'index' => 'veenendaal2',
    'type' => 'passanten2',
    'body' => [
        'query' => [
          'match_all' => [],
        ],
    ],
  ];

它工作正常,但我需要 2 个日期之间的结果!

我也试过这个,但没有结果:

  $json = '{
    "query": {
      "bool": {
        "must": [
                {
                  "range": {
                  "Tijdsperiode": {
                    "gt": "2016-01-30 07:00:00",
                    "lt":  "2016-01-30 09:00:00"
                  }
                    }
                }
            ]
        }
    }
}';
  $client = ckan_graphmapper_client();
  $params = [
    'index' => 'veenendaal2',
    'type' => 'passanten2',
    'body' => $json
  ];
  $response = $client->search($params);

我也尝试了映射:

  $params = [
    'index' => 'veenendaal2',
    'type' => 'passanten2',
    'size' => $size,
    'body' => [
      'query' => [
        "match_all" => [],
        'filter' => [
          'range' => [
            'Tijdsperiode' => [
              'gte' => '2016-01-30 01:00:00',
              'lte' => '2016-01-30 08:00:00'
            ]
          ]
        ]
      ],
      'mappings' => [
        '_default_' => [
          'properties' => [
            'Tijdsperiode' => [
              'type' => 'date',
              'format' => 'yyyy-MM-dd HH:mm:ss'
            ]
          ]
        ]
      ]
    ]
  ];

如何在 2 个日期之间进行选择的正确语法?两种字符串格式 ( 2016-01-30 00:00:00 ) ( 年-月-日 hh:毫米:SS )

谢谢!

所以事实证明,我导入的数据没有以正确的方式映射。日期字段被识别为字符串值。

当我在弹性中拥有正确的映射时,我可以执行此查询:

 $query = [
    'query' => [
      'filtered' => [
        'query' => [
          'match_all' => []
        ],
        'filter' => [
          'range' => [
            'Tijdsperiode' => [
              'gte' => $start,
              'lte' => $end
            ]
          ]
        ]
      ]
    ]
  ];