课程大纲
1、批量查询的好处
就是一条一条的查询,比如说要查询100条数据,那么就要发送100次网络请求,这个开销还是很大的
如果进行批量查询的话,查询100条数据,就只要发送1次网络请求,网络请求的性能开销缩减100倍
2、mget的语法
(1)mget批量查询
ES 7.X 不需要指定 type :
GET /_mget
{
"docs":[
{
"_index":"shop",
"_id":1
},
{
"_index":"shop",
"_id":2
}
]
}
等价:
GET /shop/_mget
{
"docs":[
{
"_id":1
},
{
"_id":2
}
]
}
{
"docs" : [
{
"_index" : "shop",
"_type" : "_doc",
"_id" : "1",
"_version" : 1,
"_seq_no" : 0,
"_primary_term" : 1,
"found" : true,
"_source" : {
"name" : "iphone XP",
"price" : "7890",
"system" : "IOS 13",
"CPU" : "xiaolong 14"
}
},
{
"_index" : "shop",
"_type" : "_doc",
"_id" : "2",
"_version" : 2,
"_seq_no" : 2,
"_primary_term" : 1,
"found" : true,
"_source" : {
"name" : "huawei Mate30",
"price" : "9890",
"system" : "hongmeng 3.0",
"CPU" : "qinglin 990"
}
}
]
}
(2)如果查询的document是一个index下的不同type种的话<废除>
GET /test_index/_mget
{
"docs" : [
{
"_type" : "test_type",
"_id" : 1
},
{
"_type" : "test_type",
"_id" : 2
}
]
}
(3)如果查询的数据都在同一个index下的同一个type下,最简单了
GET /shop/_mget
{
"ids":[
1,2
]
}
3、mget的重要性
可以说mget是很重要的,一般来说,在进行查询的时候,如果一次性要查询多条数据的话,那么一定要用batch批量操作的api
尽可能减少网络开销次数,可能可以将性能提升数倍,甚至数十倍,非常非常之重要