2

我想使用 Java Api 使用特定字段更新我的一些索引数据。我已经参考了这个文档https://www.elastic.co/guide/en/elasticsearch/client/java-api/current/java-docs-update.html并创建了一个 java 程序。我的 Java 程序如下所示:

public class App {

  public static void main(String[] args) throws Exception {
    Client client = TransportClient.builder().build().addTransportAddress(
        new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"),
            9300));
UpdateRequest updateRequest = new UpdateRequest("pibindex", "SearchTech",
        "http://www.sea.com/bundle")
            .script(new Script("ctx._source.default_collection = \"true\""));
    client.update(updateRequest).get();
   }
}

该程序正在根据脚本更新单个文档。“pibindex”是我的索引的名称,“SearchTech”是我的索引的类型,“ http://www.sea.com/bundle ”是我的文档的 ID。我想用一个新字段 "wiki_collection":true 更新多个文档,它匹配像 " http://www.sea.com/bundle " 这样的模式。我想使用通配符查询。

我正在尝试用 Java 实现这个 elasticsearch 查询:

POST /pibindex2/_update_by_query
{
  "script": {
    "inline": "ctx._source.wiki_collection=true"
  },
      "query": {
        "wildcard": {
          "url": {
            "value": "http://www.sea.com/bundle/*"
          }
        }
      }
}

抱歉,如果我遗漏了一些明显的东西。谢谢你。

4

1 回答 1

3

你可以这样试试:

import static org.elasticsearch.index.query.QueryBuilders.wildcardQuery;

BulkIndexByScrollResponse r = ubqrb.source("twitter")
    .script(script)
    .filter(wilcardQuery("url", "http://www.sea.com/bundle/*"))
    .get();

尽管结果将取决于您的url字段是否被分析。

于 2016-05-13T16:56:20.770 回答