Elasticsearch lowercase filter search

后端 未结 2 1509
长发绾君心
长发绾君心 2021-02-13 10:13

I\'m trying to search my database and be able to use upper/lower case filter terms but I\'ve noticed while query\'s apply analyzers, I can\'t figure out how to appl

相关标签:
2条回答
  • 2021-02-13 10:52

    This may be achieved by appending .keyword to your field to query against the keyword version of the field. Assuming language was defined in the mapping with type keyword.

    Note that now only the exact text would match: mandarin won't match and Italian would.

    Your query would end up like this:

    {
        "query": {
            "filtered": {
                "filter": {
                    "bool": {
                        "should": [
                            {
                                "term": {
                                    "language.keyword": "mandarin" // Returns Empty
                                }
                            },
                            {
                                "term": {
                                    "language.keyword": "Italian" // Returns Italian.
                                }
                            }
                        ]
                    }
                }
            }
        }
    }
    

    Combining the term values is also allowed:

    {
        "query": {
            "filtered": {
                "filter": {
                    "bool": {
                        "should": [
                            {
                                "term": {
                                    "language.keyword":
                                         ["mandarin", "Italian"]
                                }
                            }
                        ]
                    }
                }
            }
        }
    }
    
    0 讨论(0)
  • 2021-02-13 11:08

    The problem is that you have a field that you have analyzed during index to lowercase it, but you are using a term filter for the query which is not analyzed:

    Term Filter

    Filters documents that have fields that contain a term (not analyzed). Similar to term query, except that it acts as a filter.

    http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/query-dsl-term-filter.html

    I'd try using a query filter instead:

    Query Filter

    Wraps any query to be used as a filter. Can be placed within queries that accept a filter.

    Example:

    {
        "constantScore" : {
            "filter" : {
                "query" : {
                    "query_string" : {
                        "query" : "this AND that OR thus"
                    }
                }
            }
        } }
    

    http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/query-dsl-query-filter.html#query-dsl-query-filter

    0 讨论(0)
提交回复
热议问题