首页 > 解决方案 > 范围运算符返回错误结果的弹性搜索结果

问题描述

范围运算符返回错误结果的弹性搜索结果

在此处输入图像描述

弹性搜索查询

{"query": {"bool": {"filter": [{"term": {"Id": {"value": "v1"}}},{"term": {"Segment": {"value": 1}}},     {"term": {"Attribute": {"value": "Test"}}},{"range": {"Value_Min": {"lte": 999999996}}},{"range": {"Value_Max": {"gte": 999999996}}}]}}, "sort": [{"Value_Min": {"order": "asc"}}], "size": 10}

表中的前两列是完全匹配,表中的第 3 和第 4 列是范围操作 用于范围操作()值 min 和 value max 的数据类型是浮点数。当我搜索小值时,我正在搜索大值(999999996),它返回正确的值。

搜索查询是否依赖于范围运算符的数据类型?

我期待结果中有一行,这是此处提到的表格的第二行。但是从弹性搜索头搜索时我得到了所有行

标签: c#elasticsearch

解决方案


这是由于浮点精度。

您需要将您的Value_MinValue_Max字段更改为 typedouble而不是,float您的查询将按您期望的方式运行。


推荐阅读