Rumah >Java >javaTutorial >Bagaimana untuk menyelesaikan masalah SpringBoot mengintegrasikan medan pulangan carian parsing ES
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 }
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 } } ] } }
took
Nilai memberitahu kami tempoh masa yang diambil untuk. laksanakan keseluruhan permintaan carian Berapa milisaat.
_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.
timed_out
Nilai memberitahu kami sama ada pertanyaan tamat. Secara lalai, permintaan carian tidak tamat masa.
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.
@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 } } ] } }
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!