Я хочу сделать частичные обновления, добавив элемент в мой список пользователей:
"users" : [
{
"password" : "pwd",
"level" : "admin",
"user_name" : "XX",
"last_name" : "YY",
"first_name" : "ZZ"
}
]
с использованием Kibana Я попробовал этот запрос:
POST my_index/user/1/_update
{
"script" : {
"source": "ctx._source.users.add(params.user)",
"lang": "painless",
"params" : {
"user": {
"user_name" : "user",
"first_name" : "XX",
"last_name" : "XX",
"level" : "simple",
"password" : "pwd!#"
}
}
}
}
отлично работает:
"users" : [
{
"password" : "pwd",
"level" : "admin",
"user_name" : "XX",
"last_name" : "YY",
"first_name" : "ZZ"
},
{
"password" : "pwd!#",
"level" : "simple",
"user_name" : "user",
"last_name" : "XX",
"first_name" : "XX"
}
]
Я хочу сделать это с помощью Java-клиента, я пробовал этот код:
XContentBuilder builder = XContentFactory.jsonBuilder();
builder.startObject();
{
builder.field("user_name", user.getUserName());
builder.field("first_name", user.getFirstName());
builder.field("last_name", user.getLastName());
builder.field("level", user.getLevel());
builder.field("password", user.getPassword());
}
builder.endObject();
params.put("user", Strings.toString(builder));
UpdateByQueryRequest setScript = request.setScript(
new Script(
ScriptType.INLINE, "painless",
"ctx._source.users.add(params)",
params));
request.setScroll(TimeValue.timeValueMinutes(10));
BulkByScrollResponse bulkResponse = restHighLevelClient.updateByQuery(request, RequestOptions.DEFAULT);
В результате у меня было:
"users" : [
{
"password" : "pwd",
"level" : "admin",
"user_name" : "XX",
"last_name" : "YY",
"first_name" : "ZZ"
},
{
"user" : """{"user_name":"XX","first_name":"XX","last_name":"XX","level":"XX","password":"XX"}""",
"ctx" : {
"_routing" : null,
"_parent" : null,
"_index" : "administration",
"_type" : "environnement",
"_id" : "1",
"_version" : 24
}
}
]
так что это не правильно, я хочу, чтобы к пользователям добавлялась только пользовательская информация, и я не хочу индексировать информацию ctx.
Спасибо!