Rumah  >  Artikel  >  Java  >  Bagaimana untuk menyelesaikan masalah SpringBoot mengintegrasikan medan pulangan carian parsing ES

Bagaimana untuk menyelesaikan masalah SpringBoot mengintegrasikan medan pulangan carian parsing ES

PHPz
PHPzke hadapan
2023-05-16 08:13:071256semak imbas

    1 Struktur data

    Indeks 2 dokumen ke dalam indeks hotel:

    PUT /hotel/_doc/1
    {
      "title": "文雅酒店",
      "city": "青岛",
      "price": 556,
      "create_time": "20200418120000",
      "amenities": "浴池,普通停车场/充电停车场",
      "full_room": false,
      "location": {
        "lat": 36.083078,
        "lon": 120.37566
      },
      "praise": 10
    }
    
    PUT /hotel/_doc/2
    {
      "title": "金都嘉怡假日酒店",
      "city": "北京",
      "price": 337,
      "create_time": "20210315200000",
      "amenities": "wifi,充电停车场/可升降停车场",
      "full_room": false,
      "location": {
        "lat": 39.915153,
        "lon": 116.403
      },
      "praise": 60
    }
    
    PUT /hotel/_doc/1
    {
      "title": "文雅酒店",
      "city": "青岛",
      "price": 556,
      "create_time": "20200418120000",
      "amenities": "浴池,普通停车场/充电停车场",
      "full_room": false,
      "location": {
        "lat": 36.083078,
        "lon": 120.37566
      },
      "praise": 10
    }
    
    PUT /hotel/_doc/2
    {
      "title": "金都嘉怡假日酒店",
      "city": "北京",
      "price": 337,
      "create_time": "20210315200000",
      "amenities": "wifi,充电停车场/可升降停车场",
      "full_room": false,
      "location": {
        "lat": 39.915153,
        "lon": 116.403
      },
      "praise": 60
    }

    2 dokumen

     GET /hotel/_search
    {
      "took" : 499,
      "timed_out" : false,
      "_shards" : {
        "total" : 5,
        "successful" : 5,
        "skipped" : 0,
        "failed" : 0
      },
      "hits" : {
        "total" : {
          "value" : 2,
          "relation" : "eq"
        },
        "max_score" : 1.0,
        "hits" : [
          {
            "_index" : "hotel",
            "_type" : "_doc",
            "_id" : "2",
            "_score" : 1.0,
            "_source" : {
              "title" : "金都嘉怡假日酒店",
              "city" : "北京",
              "price" : 337,
              "create_time" : "20210315200000",
              "amenities" : "wifi,充电停车场/可升降停车场",
              "full_room" : false,
              "location" : {
                "lat" : 39.915153,
                "lon" : 116.403
              },
              "praise" : 60
            }
          },
          {
            "_index" : "hotel",
            "_type" : "_doc",
            "_id" : "1",
            "_score" : 1.0,
            "_source" : {
              "title" : "文雅酒店",
              "city" : "青岛",
              "price" : 556,
              "create_time" : "20200418120000",
              "amenities" : "浴池,普通停车场/充电停车场",
              "full_room" : false,
              "location" : {
                "lat" : 36.083078,
                "lon" : 120.37566
              },
              "praise" : 10
            }
          }
        ]
      }
    }

    3 penghuraian medan hasil carian ElasticSearch

    1 mengambil masa Berapa milisaat yang diambil oleh permintaan carian

    took Nilai memberitahu kami tempoh masa yang diambil untuk. laksanakan keseluruhan permintaan carian Berapa milisaat.

    2. Jumlah bilangan serpihan yang mengambil bahagian dalam pertanyaan

    _shards memberitahu kami jumlah bilangan serpihan yang mengambil bahagian dalam pertanyaan, dan berapa banyak serpihan ini berjaya dan berapa banyak yang gagal. Biasanya kita tidak mahu sharding gagal, tetapi sharding kegagalan boleh berlaku. Jika kami mengalami kegagalan besar di mana data asal dan replika serpihan yang sama hilang, replika tidak akan tersedia untuk serpihan itu untuk membalas permintaan carian. Jika ya, Elasticsearch akan melaporkan serpihan ini sebagai gagal, tetapi akan terus mengembalikan hasil untuk serpihan yang tinggal.

    3. tamat_masa Sama ada pertanyaan tamat masa

    timed_out Nilai memberitahu kami sama ada pertanyaan tamat. Secara lalai, permintaan carian tidak tamat masa.

    4 hits mewakili hasil carian

    Bahagian terpenting hasil yang dikembalikan ialah hits, yang mengandungi medan total untuk mewakili jumlah dokumen yang dipadankan dan Tatasusunan hits Mengandungi sepuluh dokumen pertama yang terhasil daripada pertanyaan. Apabila menghuraikan hasil carian, biasanya kita perlu memberi perhatian kepada medan berikut:

    hits.total.value: Jumlah bilangan dokumen yang sepadan.
    hits.max_score: Nilai maksimum _skor dokumen yang sepadan dengan pertanyaan.
    hits.hits: Senarai dokumen yang sepadan.
    hits.hits._source: Data mentah dokumen yang dipadankan.
    hits.hits._score: Markah dokumen yang sepadan. Ia mengukur sejauh mana dokumen sepadan dengan pertanyaan Secara lalai, hasil dokumen yang paling berkaitan dikembalikan dahulu, iaitu, dokumen yang dikembalikan diisih mengikut tertib menurun.
    hits.hits.highlight: Serlahkan maklumat dokumen yang sepadan.

    4. SpringBoot menyepadukan ElasticSearch untuk mendapatkan hasil carian

    @Slf4j
    @Service
    public class ElasticSearchImpl {
    
        @Autowired
        private RestHighLevelClient restHighLevelClient;
    
        public void searchUser() throws IOException {
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            SearchRequest searchRequest = new SearchRequest(new String[]{"hotel"},searchSourceBuilder);
            SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
    
            TimeValue took = searchResponse.getTook();
            System.out.println("took = " + took);
    
            // 搜索结果
            SearchHits searchHits = searchResponse.getHits();
    
            // hits.total.value:匹配的文档总数
            TotalHits totalHits = searchHits.getTotalHits();
            long value = totalHits.value;
            System.out.println("value = " + value);
    
            // hits.max_score:与查询所匹配文档的_score的最大值
            float maxScore = searchHits.getMaxScore();
            System.out.println("maxScore = " + maxScore);
    
            // hits.hits:匹配的文档列表
            SearchHit[] hits = searchHits.getHits();
            for (SearchHit hit : hits) {
                // hits.hits._source:匹配的文档的原始数据
                String sourceAsString = hit.getSourceAsString();
                System.out.println("sourceAsString = " + sourceAsString);
    
                //  hits.hits._id:匹配的文档的id
                String id = hit.getId();
                System.out.println("id = " + id);
    
                Map<String, DocumentField> fields = hit.getFields();
                System.out.println("fields = " + fields);
    
                String index = hit.getIndex();
                System.out.println("index = " + index);
    
                float score = hit.getScore();
                System.out.println("score = " + score);
            }
            System.out.println(searchResponse);
    
        }
    }
    
    @Slf4j
    @Service
    public class ElasticSearchImpl {
    
        @Autowired
        private RestHighLevelClient restHighLevelClient;
    
        public void searchUser() throws IOException {
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            SearchRequest searchRequest = new SearchRequest(new String[]{"hotel"},searchSourceBuilder);
            SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
    
            TimeValue took = searchResponse.getTook();
            System.out.println("took = " + took);
    
            // 搜索结果
            SearchHits searchHits = searchResponse.getHits();
    
            // hits.total.value:匹配的文档总数
            TotalHits totalHits = searchHits.getTotalHits();
            long value = totalHits.value;
            System.out.println("value = " + value);
    
            // hits.max_score:与查询所匹配文档的_score的最大值
            float maxScore = searchHits.getMaxScore();
            System.out.println("maxScore = " + maxScore);
    
            // hits.hits:匹配的文档列表
            SearchHit[] hits = searchHits.getHits();
            for (SearchHit hit : hits) {
                // hits.hits._source:匹配的文档的原始数据
                String sourceAsString = hit.getSourceAsString();
                System.out.println("sourceAsString = " + sourceAsString);
    
                //  hits.hits._id:匹配的文档的id
                String id = hit.getId();
                System.out.println("id = " + id);
    
                Map<String, DocumentField> fields = hit.getFields();
                System.out.println("fields = " + fields);
    
                String index = hit.getIndex();
                System.out.println("index = " + index);
    
                float score = hit.getScore();
                System.out.println("score = " + score);
            }
            System.out.println(searchResponse);
    
        }
    }
    took=2ms
    value = 2
    maxScore = 1.0
    
    sourceAsString = {"title":"金都嘉怡假日酒店","city":"北京","price":337,"create_time":"20210315200000","amenities":"wifi,充电停车场/可升降停车场","full_room":false,"location":{"lat":39.915153,"lon":116.403},"praise":60}
    id = 2
    fields = {}
    index = hotel
    score = 1.0
    
    sourceAsString = {"title":"文雅酒店","city":"青岛","price":556,"create_time":"20200418120000","amenities":"浴池,普通停车场/充电停车场","full_room":false,"location":{"lat":36.083078,"lon":120.37566},"praise":10}
    id = 1
    fields = {}
    index = hotel
    score = 1.0
    {
        "took": 2,
        "timed_out": false,
        "_shards": {
            "total": 5,
            "successful": 5,
            "skipped": 0,
            "failed": 0
        },
        "hits": {
            "total": {
                "value": 2,
                "relation": "eq"
            },
            "max_score": 1.0,
            "hits": [
                {
                    "_index": "hotel",
                    "_type": "_doc",
                    "_id": "2",
                    "_score": 1.0,
                    "_source": {
                        "title": "金都嘉怡假日酒店",
                        "city": "北京",
                        "price": 337,
                        "create_time": "20210315200000",
                        "amenities": "wifi,充电停车场/可升降停车场",
                        "full_room": false,
                        "location": {
                            "lat": 39.915153,
                            "lon": 116.403
                        },
                        "praise": 60
                    }
                },
                {
                    "_index": "hotel",
                    "_type": "_doc",
                    "_id": "1",
                    "_score": 1.0,
                    "_source": {
                        "title": "文雅酒店",
                        "city": "青岛",
                        "price": 556,
                        "create_time": "20200418120000",
                        "amenities": "浴池,普通停车场/充电停车场",
                        "full_room": false,
                        "location": {
                            "lat": 36.083078,
                            "lon": 120.37566
                        },
                        "praise": 10
                    }
                }
            ]
        }
    }

    5 soalan temu bual untuk hasil carian ElasticSearch

    Apakah medan _score dalam hasil carian ElasticSearch ?

    Jawapan: Medan _skor menunjukkan skor perkaitan dokumen padanan Semakin tinggi skor, semakin tinggi tahap padanan.

    2. Apakah maksud medan serlahan dalam hasil carian ElasticSearch?

    Jawapan: Medan serlahan menunjukkan medan yang diserlahkan dalam dokumen yang sepadan dan kandungannya yang diserlahkan.

    3. Bagaimana untuk mendapatkan jumlah dokumen dalam hasil carian ElasticSearch?

    Jawapan: Jumlah bilangan dokumen yang sepadan boleh diperolehi melalui medan hits.total.value.

    4. Bagaimana untuk mendapatkan senarai dokumen yang sepadan dalam hasil carian ElasticSearch?

    Jawapan: Anda boleh mendapatkan senarai dokumen yang sepadan melalui medan hits.hits.

    5. Bagaimana untuk mendapatkan data asal dokumen yang sepadan dalam hasil carian ElasticSearch?

    Jawapan: Data asal dokumen yang sepadan boleh diperolehi melalui medan hits.hits._source.

    6. Bagaimana untuk mendapatkan maklumat yang diserlahkan bagi dokumen yang sepadan dalam hasil carian ElasticSearch?

    Jawapan: Anda boleh mendapatkan maklumat serlahan dokumen yang sepadan melalui medan hits.hits.highlight.

    7. Apakah maksud medan _shards dalam hasil carian ElasticSearch?

    Jawapan: Medan _shards mewakili maklumat serpihan yang terlibat dalam carian, termasuk jumlah bilangan serpihan, bilangan serpihan yang berjaya, bilangan serpihan yang dilangkau dan bilangan serpihan yang gagal.

    8. Apakah maksud medan yang diambil dalam hasil carian ElasticSearch?

    Jawapan: Medan ambil menunjukkan masa carian, dalam milisaat.

    Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah SpringBoot mengintegrasikan medan pulangan carian parsing ES. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan:
    Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam