gpt4 book ai didi

java - 为什么我无法正确查询 Elasticsearch 中的 HashMap 字段?

转载 作者:行者123 更新时间:2023-12-01 11:14:03 28 4
gpt4 key购买 nike

我正在使用 Elasticsearch v1.5.2。我有一个如下所示的 JSON 文档。

{
"id": "RRRZe32",
"metadata": {
"published": "2010-07-29T18:11:43.000Z",
"codeId": "AChdUxnsuRyoCo7roK6gqZSg",
"codeTitle": "something"
}
}

支持此 JSON 的 Java POJO 对象如下所示。请注意,我使用的是带有 spring-boot-starter-data-elasticsearch 依赖项的 Spring-Boot v1.3.0.M2。

@Document(indexName="ws", type="vid")
public class Video {
@Id
private String id;


@Field(type=FieldType.Object, index=FieldIndex.not_analyzed)
private Map<String, Object> metadata;
}

我的映射定义如下。

{
"ws": {
"mappings": {
"vid": {
"properties": {
"id": {
"type": "string"
},
"metadata": {
"properties": {
"codeId": {
"type": "string"
},
"codeTitle": {
"type": "string"
}
}
}
}
}
}
}
}

我可以通过 metadata.codeTitle 成功查询文档(使用 Sense),但不能通过 metadata.codeId 查询。我对 metadata.codeTitle 的查询如下所示。

{
"query": {
"bool": {
"must": [
{
"term": {
"metadata.codeTitle": {
"value": "something"
}
}
}
]
}
}
}

我对 metadata.codeId 的查询如下所示。

{
"query": {
"bool": {
"must": [
{
"term": {
"metadata.codeId": {
"value": "AChdUxnsuRyoCo7roK6gqZSg"
}
}
}
]
}
}
}

关于我做错了什么有什么想法吗?

最佳答案

这是因为您的 codeId 字段已被分析并且该值在索引时变为小写。所以你有两个解决方案:

可以这样查询(即全部小写)

{
"query": {
"bool": {
"must": [
{
"term": {
"metadata.codeId": {
"value": "achduxnsuryoco7rok6gqzsg"
}
}
}
]
}
}
}

或者您可以将 codeId 字段声明为 not_analyzed 并保持查询不变。

就您的情况而言,情况 1 看起来更容易实现。

关于java - 为什么我无法正确查询 Elasticsearch 中的 HashMap 字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32044307/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com