flex 搜索结果,范围运算符返回错误结果
ElasticSerchQuery
{"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}
表中的前两列是完全匹配,表中的第三和第四列是范围运算用于范围operation()的min和max值的数据类型为float。
我正在搜索大值(999999996),当我搜索小值时,它将返回正确的值。
搜索查询是否取决于范围运算符的数据类型?
我期望结果中有一行,这是这里提到的表的第二行。
但是从 flex 搜索头搜索时我得到了所有行
最佳答案
这是由于浮点精度。
您需要将Value_Min
和Value_Max
字段更改为double
而不是float
类型,并且查询将按您期望的方式进行。
关于c# - Elasticsearch 结果,范围运算符返回错误结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63170486/