gpt4 book ai didi

java - Elasticsearch精确匹配查询问题

转载 作者:行者123 更新时间:2023-12-02 01:58:08 25 4
gpt4 key购买 nike

我在查询 Elasticsearch 时遇到问题。以下是我的查询

GET _search {
"query": {
"bool": {
"must": [{
"match": {
"name": "SomeName"
}
},
{
"match": {
"type": "SomeType"
}
},
{
"match": {
"productId": "ff134be8-10fc-4461-b620-79s51199c7qb"
}
},
{
"range": {
"request_date": {
"from": "2018-08-22T12:16:37,392",
"to": "2018-08-28T12:17:41,137",
"format": "YYYY-MM-dd'T'HH:mm:ss,SSS"
}
}
}

]
}
}
}

我在 boolean 查询中使用了三个匹配查询和一个范围查询。我的目的是获取具有这些完全匹配且在此日期范围内的文档。在这里,如果我更改名称和类型值,我将不会得到结果。但对于 ProductId ,如果我只输入 ff134be8,我就会得到结果。有人知道这是为什么吗? 。精确匹配适用于名称和类型,但不适用于 ProductId

最佳答案

您需要将您的productId 映射到keyword 以避免标记化。使用标准分词器 "ff134be8-10fc-4461-b620-79s51199c7qb" 将创建 ["ff134be8", "10fc", "4461", "b620", "79s51199c7qb"] 作为标记。

您有不同的选择:

1/使用term query在不分析字段内容的情况下进行检查

...
{
"term": {
"productId": "ff134be8-10fc-4461-b620-79s51199c7qb"
}
},
...

2/如果您使用的是 Elasticsearch 6.X,您可以将请求更改为

...
{
"match": {
"productId.keyword": "ff134be8-10fc-4461-b620-79s51199c7qb"
}
},
...

因为elasticsearch将为所有字符串字段创建一个类型为keyword的子字段keyword

最好的选择当然是第一个。如果您想匹配确切的内容,请始终使用术语查询

关于java - Elasticsearch精确匹配查询问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52037158/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com