有没有办法在Elasticsearch查询中排除字段

时间:2013-08-13 23:23:13

标签: elasticsearch

我知道使用字段设置只在搜索http://www.elasticsearch.org/guide/reference/api/search/fields/

中包含我想要的字段

...但是我想知道我是否可以做相反的事情......以某种方式指定一个或两个我不希望包含在查询结果中的字段(例如附件)。当我只能指定要排除的字段

时,必须输入我想要的所有字段减去一两个似乎很痛苦

2 个答案:

答案 0 :(得分:12)

您可以使用源过滤(在第1.6节和第1.7节中测试):https://www.elastic.co/guide/en/elasticsearch/reference/current/search-request-source-filtering.html

{
    "_source": {
        "include": [ "obj1.*", "obj2.*" ],
        "exclude": [ "*.description" ]
    },
    "query" : {
        "term" : { "user" : "kimchy" }
    }
}

您也可以在GET请求中使用它:

curl "localhost:9200/myindex/mytype/66a8f299870b4cab?_source_exclude=file._content&pretty"

上一个示例排除了附件字段中的文件内容。

答案 1 :(得分:7)

您是否在问题中链接的同一页面上看到了“部分”的文档?这可以让你做你想做的事,虽然只在我认为的'_source'字段。见https://www.elastic.co/guide/en/elasticsearch/reference/1.7/search-request-fields.html

  

_source加载数据时,可以使用partial字段   通配符,用于控制基于_source加载的部分   includeexclude模式。

     

includeexclude都支持多种模式:

{
    "query" : {
        "match_all" : {}
    },
    "partial_fields" : {
        "partial1" : {
            "include" : ["obj1.obj2.*", "obj1.obj4.*"],
            "exclude" : "obj1.obj3.*"
        }
    }
}