最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to delete multiple id documents in elasticsearch index - Stack Overflow

programmeradmin3浏览0评论
var elasticsearch = require('elasticsearch');
var client = new elasticsearch.Client({
    host: 'ABC',
    log: 'trace',
    apiVersion: '7.1'
});
client.delete({
        index: 'allevents',
        type: '_doc',
        id:"2"
    }).then(function(resp) {
        console.log("Successful query!");
        console.log(JSON.stringify(resp, null, 4));
    }, function(err) {
        console.trace(err.message);
    });

When I delete a single document by passing single id value.its working fine.

But I want to delete multiple documents in a single query. How will we do?

I tried

 client.delete({
    index: 'allevents',
    type: '_doc',
    id: ["2","3"]
})

This function returning error.

var elasticsearch = require('elasticsearch');
var client = new elasticsearch.Client({
    host: 'ABC',
    log: 'trace',
    apiVersion: '7.1'
});
client.delete({
        index: 'allevents',
        type: '_doc',
        id:"2"
    }).then(function(resp) {
        console.log("Successful query!");
        console.log(JSON.stringify(resp, null, 4));
    }, function(err) {
        console.trace(err.message);
    });

When I delete a single document by passing single id value.its working fine.

But I want to delete multiple documents in a single query. How will we do?

I tried

 client.delete({
    index: 'allevents',
    type: '_doc',
    id: ["2","3"]
})

This function returning error.

Share Improve this question asked Sep 25, 2019 at 11:45 Rahul SainiRahul Saini 9371 gold badge11 silver badges29 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 8

I suggest to leverage the bulk method/API, like this:

var elasticsearch = require('elasticsearch');
var client = new elasticsearch.Client({
    host: 'ABC',
    log: 'trace',
    apiVersion: '7.1'
});

var idsToDelete = ["2", "3"];
var bulk = idsToDelete.map(id => {
  return {
     'delete': {
        '_index': 'allevents',
        '_type': '_doc',
        '_id': id
     }
  };
});

client.bulk({
      body: bulk
    }).then(function(resp) {
        console.log("Successful query!");
        console.log(JSON.stringify(resp, null, 4));
    }, function(err) {
        console.trace(err.message);
    });

Another way of doing it is to leverage the deleteByQuery method/API:

var elasticsearch = require('elasticsearch');
var client = new elasticsearch.Client({
    host: 'ABC',
    log: 'trace',
    apiVersion: '7.1'
});

var idsToDelete = ["2", "3"];

client.deleteByQuery({
      index: 'allevents',
      type: '_doc',
      body: {
        query: {
          terms: {
            _id: idsToDelete
          }
        }
      }
    }).then(function(resp) {
        console.log("Successful query!");
        console.log(JSON.stringify(resp, null, 4));
    }, function(err) {
        console.trace(err.message);
    });
发布评论

评论列表(0)

  1. 暂无评论