在 Elasticsearch 7.x 中,文本类型字段存储的是被分词器处理后的文本,它们没有固定的长度限制。因此,无法通过简单地查询文本字段来获取其长度。
如果你需要获取文本字段中的字符数或字节数,则可以使用脚本字段计算该值。以下是一个示例查询,用于获取名为“my_text_field”的文本字段中字符的数量:
GET /my_index/_search
{
"query": {
"match_all": {}
},
"script_fields": {
"field_length": {
"script": {
"source": "doc['my_text_field.keyword'].value.length()"
}
}
}
}
这个查询将返回一个包含每个文档中“my_text_field”字段字符数量的结果集。注意到我们在脚本中使用了 keyword
后缀来访问原始文本字段而不是分词后的版本。
如果你想要对所有文档进行聚合操作并计算出平均值、最小值或最大值等统计数据,你可以使用聚合操作。以下是一个示例查询,它将按照 “my_text_field” 字段中字符数量对所有文档进行聚合,并计算出平均值和最大值:
GET /my_index/_search
{
"size": 0,
"aggs": {
"avg_length": {
"avg": {
"script": {
"source": "doc['my_text_field.keyword'].value.length()"
}
}
},
"max_length" : {
"max" : {
"script" : {
"source": "doc['my_text_field.keyword'].value.length()"
}
}
}
}
}
该查询将返回两个聚合操作结果,“avg_length” 和 “max_length”,它们分别是 “my_text_field” 字段中字符数量的平均值和最大值。