问题描述
"doc1":{
"dummy_attribute":"HI",...
"important_attribute":{}
}
"doc2":{
"dummy_attribute":"HI",...
}
如果我这样搜索:
GET myindex/_search
{
"query": {
"bool": {
"must_not": [{
"exists": {
"field": "important_attribute"
}
}]
}
}
}
它给我两个文件。 有没有一种方法可以只搜索文档中实际上不存在“ important_attribute”的文档?
解决方法
不幸的是,由于ES treats a non-existent value the same way as an empty-ish value(null
,""
,[]
或{}
),这是不可能的。
您可以使用脚本字段快速检查文档是否包含空字典,但是在过滤时无法使用此上下文:
GET myindex/_search
{
"query": {
"bool": {
"must_not": [
{
"exists": {
"field": "important_attribute"
}
}
]
}
},"script_fields": {
"has_empty_dict": {
"script": {
"source": "params._source.containsKey('important_attribute') && params._source.important_attribute.size() == 0"
}
}
}
}