spring cloud 集成elasticsearch 实现findByIds查询

spring cloud 集成elasticsearch 实现findByIds查询,第1张

spring cloud 集成elasticsearch 实现findByIds查询

我们使用elasticsearch常使用它的分词查询,但是因为业务需要也需要使用多id查询,elasticsearch提供了MultiGetRequest实现多ids,多索引查询:

    public  List findByIds(List keys, Class clazz) {
        RestHighLevelClient client=this.restHighLevelClient();
        try {
            if(null == keys || keys.size() == 0){
                return  null;
            }
            // 通过MultiGetRequest.Item对象设置查询参数
            MultiGetRequest request = new MultiGetRequest();
            String[] ids = new String[keys.size()];
            for(int i = 0;i< keys.size();i++){
                ids[i] = keys.get(i);
                request.add( "索引名", keys.get(i));
            }
            List  productList = Lists.newArrayList();
            MultiGetResponse response = client.mget(request, RequestOptions.DEFAULT);
            log.info("ES-findById:id[{}],result:{}", JSON.toJSonString(keys),response.getResponses());
            if(!response.isFragment()){
                for(MultiGetItemResponse multiGetItemResponse :response.getResponses()){
                    GetResponse firstGet = multiGetItemResponse.getResponse();
                    if (firstGet.isExists()) {
                        String value =firstGet.getSourceAsString();
                        productList.add(JSONObject.parseObject(value,clazz)) ;
                    }
                }
            }
            return productList;
        } catch (Exception e) {
            throw new BizException(" findByIndexIds 搜索引擎异常:"+e.getMessage());
        }finally {
            try {
                client.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5717509.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-18

发表评论

登录后才能评论

评论列表(0条)

保存