我使用Elasticsearch 11作为查询文本。
我有下面的查询,但它没有返回任何文档。
POST/_search
{
"query": {
"term":{
"metric_name" : {"value": "ConsumedReadCapacityUnits","boost": 1.0}
}
}
}然后我将其更改为text查询,如下所示,它可以查找匹配的文档:
POST/_search
{
"query": {
"match":{
"metric_name" : "ConsumedReadCapacityUnits"
}
}
}根据term查询中的文档,它匹配精确的术语,但是对于metric_name,值ConsumedReadCapacityUnits是精确的,那么为什么term查询不返回任何内容呢?
发布于 2021-08-19 02:11:34
匹配查询根据标准分析器(如果未指定分析器)分析搜索词,然后将分析的词与倒排索引中存储的词进行匹配。默认情况下,如果未指定分析器,则text类型字段使用标准分析器。例如。SchooL被分析到学校
术语查询返回在提供的字段中包含精确术语的文档。如果您尚未定义任何显式索引映射,则需要将.keyword添加到该字段。这使用关键字分析器而不是标准分析器。
正如上面评论中提到的,ConsumedReadCapacityUnits的映射类型是text,因此您可以通过更新索引映射在ConsumedReadCapacityUnits上执行术语查询
如果要将ConsumedReadCapacityUnits字段存储为文本类型和关键字类型,则可以使用update your index mapping as shown below to use multi fields
PUT /_mapping
{
"properties": {
"ConsumedReadCapacityUnits": {
"type": "text",
"fields": {
"keyword": {
"type": "keyword"
}
}
}
}
}然后再次对数据重新编制索引。在此之后,您将能够使用关键字类型的"ConsumedReadCapacityUnits.keyword“字段和文本类型的"ConsumedReadCapacityUnits”字段执行术语查询
或者,另一种方法是使用下面的索引映射创建一个新索引
{
"mappings": {
"properties": {
"ConsumedReadCapacityUnits": {
"type": "keyword"
}
}
}
}然后在这个新的索引中索引数据
https://stackoverflow.com/questions/68829639
复制相似问题