首页 > 其他分享 >ES文档操作 ,kibana-query查询

ES文档操作 ,kibana-query查询

时间:2023-09-16 20:48:15浏览次数:35  
标签:org searchRequest kibana elasticsearch import query new response ES

package cn.itcast.hotel;

import cn.itcast.hotel.constant.EsConstant;
import cn.itcast.hotel.pojo.Hotel;
import cn.itcast.hotel.pojo.HotelDoc;
import cn.itcast.hotel.service.impl.HotelService;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.http.HttpHost;
import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest;
import org.elasticsearch.action.bulk.BulkRequest;
import org.elasticsearch.action.delete.DeleteRequest;
import org.elasticsearch.action.delete.DeleteResponse;
import org.elasticsearch.action.get.GetRequest;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.action.update.UpdateResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.lucene.search.function.CombineFunction;
import org.elasticsearch.common.unit.DistanceUnit;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightField;
import org.elasticsearch.search.sort.GeoDistanceSortBuilder;
import org.elasticsearch.search.sort.SortBuilders;
import org.elasticsearch.search.sort.SortOrder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.query.functionscore.FunctionScoreQueryBuilder;
import org.elasticsearch.index.query.functionscore.ScoreFunctionBuilders;
import org.elasticsearch.search.SearchHit;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import javax.swing.*;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

/**
 * d:文档操作 ,kibana-query查询
 * Description: TODO
 * ClassName: cn.itcast.hotel.HotelDocTest
 * Author: regular
 * Version: 1.0
 */
@SpringBootTest
public class HotelDocTest {
    @Autowired
    private HotelService hotelService;
    @Autowired
    private RestHighLevelClient client;
    /**
     * 根据ID查询文档
     * @Description: HotelDocTest
     */
    @Test
    public void getDocTest() throws IOException {
        GetRequest getRequest=new GetRequest(EsConstant.HOTEL_INDEX,"36934");
        //根据ID查询文档
        GetResponse response = client.get(getRequest, RequestOptions.DEFAULT);
        String json = response.getSourceAsString();
        HotelDoc hotelDoc= JSONObject.parseObject(json, HotelDoc.class);
        System.out.println(hotelDoc);
    }
    /**
     * 添加文档
     * @Description: HotelDocTest
     */
    @Test
    public void addDocTest() throws IOException {
        Hotel hotel=hotelService.getById(36934L);//根据ID查询
        HotelDoc hotelDoc=new HotelDoc(hotel);
        //创建增加文档的请求对象
        IndexRequest indexRequest=new IndexRequest(EsConstant.HOTEL_INDEX);
        //设置文档ID与数据
        indexRequest.id(hotelDoc.getId().toString()).source(JSONObject.toJSONString(hotelDoc), XContentType.JSON);
        //执行增加文档的请求
        IndexResponse response = client.index(indexRequest, RequestOptions.DEFAULT);
        String id= response.getId();
        System.out.println("id="+id);
    }
    /**
     * 删除文档
     * @Description: HotelDocTest
     */
    @Test
    public void deleteDocTest() throws IOException {
        DeleteRequest deleteRequest=new DeleteRequest(EsConstant.HOTEL_INDEX,"36934");
        DeleteResponse response = client.delete(deleteRequest, RequestOptions.DEFAULT);
        String id=response.getId();
        System.out.println("id=" + id);
    }
    /**
     * 修改文档
     * @Description: HotelDocTest
     */
    @Test
    public void updateDocTest(){
       Hotel hotel=hotelService.getById(36934L);
         HotelDoc hotelDoc=new HotelDoc(hotel);
         hotelDoc.setName("北京饭店");
         hotelDoc.setPrice(999);
         hotelDoc.setAddress("北京市东城区");
        UpdateRequest updateRequest=new UpdateRequest(EsConstant.HOTEL_INDEX,"36934");
        updateRequest.doc(JSONObject.toJSONString(hotelDoc),XContentType.JSON);
        try {
            UpdateResponse response = client.update(updateRequest, RequestOptions.DEFAULT);
            int status = response.status().getStatus();
            System.out.println(status);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    /**
     * 批量操作文档
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void bulkRequestTest(){
        List<Hotel> hotelList=hotelService.list(null);
        List<HotelDoc> hotelDocList=new ArrayList<>(hotelList.size());
        for (Hotel hotel : hotelList) {
            HotelDoc hotelDoc=new HotelDoc(hotel);
            hotelDocList.add(hotelDoc);
        }
        BulkRequest bulkRequest=new BulkRequest();
        for (HotelDoc hotelDoc : hotelDocList) {
            //向bulkRequest中添加多个indexRequest请求
            IndexRequest indexRequest=new IndexRequest(EsConstant.HOTEL_INDEX);
            indexRequest.id(hotelDoc.getId().toString()).source(JSONObject.toJSONString(hotelDoc),XContentType.JSON);
            bulkRequest.add(indexRequest);
        }
        //执行批量操作
        try {
            client.bulk(bulkRequest,RequestOptions.DEFAULT);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 根据条件查询文档
     * @Description: HotelDocTest
     */
    @Test
    public void matchAllTest() throws IOException {
        //1.创建查询请求对象
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        //2.设置封装查询条件
        searchRequest.source().query(QueryBuilders.matchAllQuery());
        //3.执行查询
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        //4.解析查询结果
        printResult(response);
    }
    /**
     * 根据条件查询文档 multi_match
     * @Description: HotelDocTest
     */
    @Test
    public void matchMutiTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source().query(QueryBuilders.multiMatchQuery("北京","name","city","business"));
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    //抽取方法返回es数据
    private void printResult(SearchResponse response) {
        long total = response.getHits().getTotalHits().value;
        System.out.println("total=" + total);
        SearchHit[] hits = response.getHits().getHits();
        for (SearchHit hit : hits) {
            String json = hit.getSourceAsString();
            HotelDoc hotelDoc = JSONObject.parseObject(json, HotelDoc.class);
            System.out.println(hotelDoc);
        }
    }
    /**
     * 根据条件查询文档 term
     * @Description: HotelDocTest
     */
    @Test
    public void termTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source().query(QueryBuilders.termQuery("city","北京"));
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 根据条件查询文档 range
     * @Description: HotelDocTest
     */
    @Test
    public void rangeTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source().query(QueryBuilders.rangeQuery("price").gte(1000).lte(3000));
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * geo_distance
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void geoDistanceTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source().query(QueryBuilders
                //指定字段
                .geoDistanceQuery("location")
                //指定距离
                .distance("5", DistanceUnit.KILOMETERS)
                //指定坐标
                .point(31.242201,121.509106));
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);//打印结果
    }
    /**
     * 复合查询 -算分查询(根据权重确认显示)
     * #给品牌是如家的酒店增加权重积分*10
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void functionScoreTest() throws IOException {

        // 创建查询请求
        SearchRequest searchRequest = new SearchRequest("hotel");
        FunctionScoreQueryBuilder functionScoreQueryBuilder = new FunctionScoreQueryBuilder(
                //QueryBuilders.matchAllQuery(),
                QueryBuilders.termQuery("city", "上海"),
                new FunctionScoreQueryBuilder.FilterFunctionBuilder[]{
                        new FunctionScoreQueryBuilder.FilterFunctionBuilder(
                                QueryBuilders.termQuery("brand", "如家"),
                                ScoreFunctionBuilders.weightFactorFunction(10)
                        )
                }
        ).boostMode(CombineFunction.MULTIPLY);
        // 创建精确查询
        searchRequest.source().query(functionScoreQueryBuilder);
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 复合查询 -布尔查询
     *
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void boolTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        BoolQueryBuilder boolQueryBuilder = new BoolQueryBuilder();
        boolQueryBuilder.must(QueryBuilders.matchQuery("all","如家"))
                .mustNot(QueryBuilders.rangeQuery("price").gt(400))
                .filter(QueryBuilders.geoDistanceQuery("location").point(31.242201,121.509106).distance("5km"));
        searchRequest.source().query(boolQueryBuilder);
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 搜索结果处理 -根据选定普通字段排序
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
     */
    @Test
    public void sortTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source()
                .query(QueryBuilders
                        //指定字段
                        .geoDistanceQuery("location")
                        //指定坐标
                        .point(31.242201,121.509106)
                        //指定距离
                        .distance("5",DistanceUnit.KILOMETERS))
                        //排序
                        .sort("score", SortOrder.DESC)
                        .sort("price", SortOrder.ASC);
        SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 搜索结果处理 -根据地理坐标字段排序
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
     */
    @Test
    public void geoDistanceSortTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source()
                .query(QueryBuilders.matchAllQuery())
                //.sort(new GeoDistanceSortBuilder("location",31.242201,121.509106).order(SortOrder.ASC));
                .sort(
                        SortBuilders.geoDistanceSort("location",31.242201,121.509106)
                                .order(SortOrder.ASC)
                                .unit(DistanceUnit.KILOMETERS)
                );
        SearchResponse response= client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 距离升序、分页,有一个深度分页问题
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void geoDistanceSortPageTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source()
                .query(QueryBuilders.matchAllQuery())
                //排序
                .sort(
                        SortBuilders.geoDistanceSort("location",31.242201,121.509106)
                                .order(SortOrder.ASC)
                                .unit(DistanceUnit.KILOMETERS)
                )
                .from(0)
                .size(3);
        SearchResponse response= client.search(searchRequest, RequestOptions.DEFAULT);
        printResult(response);
    }
    /**
     * 高亮显示
     * @Description: HotelDocTest
     * @Author: regular
     * @Version: 1.0
    */
    @Test
    public void highlightTest() throws IOException {
        SearchRequest searchRequest=new SearchRequest(EsConstant.HOTEL_INDEX);
        searchRequest.source()
                .query(QueryBuilders.matchQuery("all","如家"))
                .highlighter(
                        new HighlightBuilder()
                                .field("name")
                                .requireFieldMatch(false)
                                .preTags("<font color='red'>")
                                .postTags("</font>"))
                .from(20).size(20);
        SearchResponse response= client.search(searchRequest, RequestOptions.DEFAULT);
        long total = response.getHits().getTotalHits().value;
        System.out.println("总条数=" + total);
        for (SearchHit hit : response.getHits().getHits()) {
            String json = hit.getSourceAsString();
            System.out.println(json);
            HotelDoc hotelDoc = JSON.parseObject(json, HotelDoc.class);
            //获取高亮片段
            HighlightField highlightField = hit.getHighlightFields().get("name");
            String text = highlightField.getFragments()[0].toString();
            System.out.println(text);
            System.out.println(hotelDoc.getName());
        }
    }

}

 

标签:org,searchRequest,kibana,elasticsearch,import,query,new,response,ES
From: https://www.cnblogs.com/qdcream/p/17707269.html

相关文章

  • ES操作索引
    packagecn.itcast.hotel;importcn.itcast.hotel.constant.EsConstant;importorg.elasticsearch.action.admin.indices.delete.DeleteIndexRequest;importorg.elasticsearch.action.support.master.AcknowledgedResponse;importorg.elasticsearch.client.RequestOpti......
  • ES相关的增删改查操作示例
    依赖:<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId></dependency>修改版本: 第一步:条件准备:首先是配置类:@ConfigurationpublicclassEsConfig{......
  • [Servlet/Tomcat] HttpServletRequest#getHeader(headerNameWithIgnoreCase)(获取heade
    1故事背景最近项目上有个业务需求,翻译成技术需求,即:将request.headers中的几个header入参转换成request.body(pageRequest)中的内置参数。为便于灵活配置,header参数名称是动态可配置的(存放于nacos配置中心),比如:sysCode、Accept-Language技术实现,主要就springmvc的org.spr......
  • BeanUtils.copyProperties用法
    //获取ActionForm表单数据UserActionFormuForm=(UserActionForm)form;//构造一个User对象Useruser=newUser();//赋值(部分==》整体)BeanUtils.copyProperties(uForm,user);注意点  1、UserActionForm==》User:部分到整体;  2、如果User和UserActionFor......
  • CUDA memories
    GlobalThere'salargeamountofglobalmemory.It'sslowertoaccessthanothermemorylikesharedandregisters.AllrunningthreadscanreadandwriteglobalmemoryandsocantheCPU.ThefunctionscudaMalloc,cudaFree,cudaMemcpy,cud......
  • XMind2TestCase安装问题
     安装完成了XMind2TestCase之后,在命令端检查安装是否成功,报错:C:\Users\Administrator>xmind2testcaseTraceback(mostrecentcalllast): File"C:\Softwares\Python\Scripts\xmind2testcase-script.py",line33,in<module> sys.exit(load_entry_point('......
  • [论文速览] SDXL@ Improving Latent Diffusion Models for High-Resolution Image Syn
    Pretitle:SDXL:ImprovingLatentDiffusionModelsforHigh-ResolutionImageSynthesisaccepted:arXiv2023paper:https://arxiv.org/abs/2307.01952code:https://github.com/Stability-AI/generative-models关键词:imagesynthesis,stablediffusion,SDXL,AICG......
  • 索引管理--ES客户端(测试创建索引库以及文档的增删改查)
    这里使用RestClient来搭建ES客户端RestClient有两种:JavaLowLevelRESTClient和JavaHighLevelRESTClient这里采用JavaHighLevelRESTClient首先添加依赖:<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsear......
  • 2020-2021 ACM-ICPC Brazil Subregional Programming Contest
    A.StickerAlbum你想要得到\(n\)张贴纸,每包礼物中等概率出现\([A,B]\)范围内数量的贴纸,求需要买多少包礼物才能至少获得\(n\)张贴纸的期望次数\(1\leqn\leq10^6,0\leqA,B\leq10^6\)题解:期望DP我们考虑从后往前进行\(dp\)设计状态为\(dp[i]\)代表手上有\(i\)张......
  • 【ERROR: Could not find a version that satisfies】【ERROR: No matching distribut
    pip包安装出错真是把我烦死了,在yt上学东西,结果一直出这样的错,之前我都是把包下载到本地安装的,这也不是长久之计。然后我试了使用-i,使用--trusted-host,使用--user,使用--upgradepip...全都不管用。后来我想,究竟是什么时候出现这个问题的,好像很久之前就有了...老提示不安全的连......