如何在ES中查询反向路径层次结构标记器?

问题描述

我有一个定义如下的索引,其中包含我对externalNodeIdpath和reverseExternalNodeIdpath感兴趣的两个字段。对于这两个字段,我使用了路径层次标记器,其中将reverseExternalNodeIdpath的反向配置标志设置为true。

{
   "dev_agreement-search-service_customer_1":{
      "mappings":{
         "properties":{
            "customer":{
               "properties":{
                  "externalNodeIdpath":{
                     "type":"text","analyzer":"custom_path_tree"
                  },"reverseExternalNodeIdpath":{
                     "type":"text","analyzer":"custom_path_tree_reversed"
                  }
               }
            }
         }
      }
   }
}

下面是我为此索引添加的数据。

1. {
   "reverseExternalNodeIdpath":"9100021.9200068.9300955.1003555","externalNodeIdpath":"9100021.9200068.9300955.1003555"
}

2. {
   "reverseExternalNodeIdpath":"9100021.9200068.9300955","externalNodeIdpath":"9100021.9200068.9300955"
}

3. {
   "reverseExternalNodeIdpath":"9100021.9200068","externalNodeIdpath":"9100021.9200068"
}

现在,当我对具有路径层次标记器并将reverse设置为true的reverseExternalNodeIdpath字段执行以下查询时,它会产生单个结果。但是我的理解是,它还应该显示其所有父项结果(例如,在externalNodeIdpath的情况下,该结果将包含路径层次标记器,但未设置为true)。像1003555的父代是9300955。9300955的父代是9200068。9200068的父代是9100021。

所以实际结果应该是全部三个,如下所示

query : GET /dev_agreement-search-service_customer_1/_search {
   "query":{
      "term":{
         "customer.reverseExternalNodeIdpath":{
            "value":"1003555"
         }
      }
   }
}

result from ES : {
   "reverseExternalNodeIdpath":"9100021.9200068.9300955.1003555","externalNodeIdpath":"9100021.9200068.9300955.1003555"
}

actual result should be :

1. {
   "reverseExternalNodeIdpath":"9100021.9200068.9300955.1003555","externalNodeIdpath":"9100021.9200068"
}

请让我知道我的理解是否正确,以及我在哪里做错了。我想为此实现自上而下的方法(externalNodeIdpath)和自下而上的方法(reverseExternalNodeIdpath查询

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...