Filter on ID values



我在使用 ID 值过滤字段时遇到问题,不确定这是怎么发生的,这是映射和示例。

添加新用户后可以看出,如果primary_user设置为 AWBFyulclsp0PJbvPiuB,除非在过滤器请求中使用keyword否则使用 filter 将无法找到它。这只发生在 ID 的值上。此行为的根本原因是什么?

   GET users/_mapping/
    Response:
    {
     ...
     ...
     "primary_user": {
                "type": "text",
                "fields": {
                  "keyword": {
                    "type": "keyword",
                    "ignore_above": 256
                  }
                }
              }
    }
------
    POST users/user
    {
      "primary_user": "AWBFyulclsp0PJbvPiuB"
    }
    Response:
    {
      "_index": "users",
      "_type": "user",
      "_id": "AWIaOFgQmedTIIkbtGPG",
      "_version": 1,
      "result": "created",
      "_shards": {
        "total": 2,
        "successful": 1,
        "failed": 0
      },
      "created": true
    }
------
    GET users/user/_search
    {
      "query": {
        "bool": {
          "filter": {
            "term": {
              "primary_user": "AWBFyulclsp0PJbvPiuB"
            }
          }
        }
      }
    }
    Response:
    {
      "took": 0,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "failed": 0
      },
      "hits": {
        "total": 0,
        "max_score": null,
        "hits": []
      }
}
------
    GET users/user/_search
    {
      "query": {
        "bool": {
          "filter": {
            "term": {
              "primary_user.keyword": "AWBFyulclsp0PJbvPiuB"
            }
          }
        }
      }
    }
    Response:
    {
        "_index": "users",
        "_type": "user",
        "_id": "AWIaOFgQmedTIIkbtGPG",
        "_score": 0,
        "_source": {
          "primary_user": "AWBFyulclsp0PJbvPiuB"
        }
      }

因为primary_user有一个文本数据类型,如映射中所写:

 "primary_user": {
            "type": "text",
            "fields": {
              "keyword": {
                "type": "keyword",
                "ignore_above": 256
              }
            }
          }

因此,或者您更改要查询的字段:

GET users/user/_search
{
  "query": {
    "bool": {
      "filter": {
        "term": {
          "primary_user.keyword": "AWBFyulclsp0PJbvPiuB"
        }
      }
    }
  }
}

或从字词更改为匹配查询:

GET users/user/_search
{
  "query": {
    "bool": {
      "filter": {
        "match": {
          "primary_user": "AWBFyulclsp0PJbvPiuB"
        }
      }
    }
  }
}

相关内容

  • 没有找到相关文章

最新更新