总结一下ES中创建文档的几种方式,并演示他们的不同
一、PUT\POST /index/_doc/<id>
#插入_id为1的数据
PUT test_zmz/_doc/1
{
“title”:“111”
}
结果
#再次插入_id为1的数据
PUT test_zmz/_doc/1
{
“title”:“222”
}
结果
POST效果相同,省略
可见,当使用PUT\POST /index/_doc/<id>插入数据的原则是:无则插入,有则覆盖
二、PUT\POST /index/_create/<id>
#使用_create的方式插入id为3的数据
PUT test_zmz/_create/3
{
“title”:“333”
}
结果
#再次插入_id为3的数据
POST test_zmz/_create/3
{
“title”:“345”
}
结果
POST效果相同,省略
可见,当使用PUT\POST /index/_create/<id>插入数据的原则是:无则插入,有则报错
三、PUT\POST /index/_create/
插入数据时不指定_id
PUT test_zmz/_create/
{
“title”:“222”
}
结果
POST test_zmz/_create/
{
“title”:“333”
}
结果
当使用PUT\POST /index/_create/ 不指定_id插入数据时会报语法错误。
四、PUT\POST /index/_doc/
#插入数据时不指定_id
PUT test_zmz/_doc/
{
“title”:“222”
}
结果
POST test_zmz/_doc/
{
“title”:“222”
}
结果
当使用PUT /index/_id/ 不指定_id插入数据时会报语法错误。
当使用POST /index/_id/ 不指定_id插入数据时会自动生成_id
看结论
#指定<_id>
PUT index/_doc/<id> #无则插入,有则覆盖
POST index/_doc/<id> #无则插入,有则覆盖
PUT index/_create/<id> #无则插入,有则报错
PUT index/_create/<id> #无则插入,有则报错
#不指定<_id>
PUT index/_doc #语法错误
POST index/_doc #自动生成_id插入
PUT index/_create #语法错误
POST index/_create #语法错误
千万注意,这里“有则覆盖”,其底层逻辑是先删除再插入,不是只更新插入字段
当然肯定还是有同学会疑惑PUT和POST在ES中有什么区别
很简单,如果该更新对应的URI多次调用的结果一致,则PUT。如果每次提交相同的内容,最终结果不一致的时候,用POST。
例如
用户注册用POST :/user/creation?user_name=&pwd=
修改用户密码用PUT :/user/{user_id}/modify?pwd=**
彩蛋
ES中还可以使用_bulk批量更新数据,如果是多字段(多字段需用逗号隔开,同时不能换行)
PUT\POST test_zmz/_bulk
{“index”:{“_id”:10}}
{“title”:“aaa”}
{“index”:{“_id”:11}}
{“title”:“bbb”}
其逻辑也是无则插入,有则覆盖