成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring Boot整合Elasticsearch,實現function score query權重分查詢

企業動態
實際場景還會很復雜。這里只是點睛之筆,優化或者更改下DSL語句就可以完成自己想要的搜索規則。

本文提綱

一、ES 的使用場景

二、運行 springboot-elasticsearch 工程

三、springboot-elasticsearch 工程代碼詳解

[[191772]]

運行環境:JDK 7 或 8,Maven 3.0+

技術棧:SpringBoot 1.5+,ElasticSearch 2.3.2

一、ES 的使用場景

簡單說,ElasticSearch(簡稱 ES)是搜索引擎,是結構化數據的分布式搜索引擎。在

《Elasticsearch 和插件 elasticsearch-head 安裝詳解》

《Elasticsearch 默認配置 IK 及 Java AnalyzeRequestBuilder 使用》

我詳細的介紹了如何安裝,初步使用了 IK 分詞器。這里,我主要講下 SpringBoot 工程中如何使用 ElasticSearch。

ES 的使用場景大致分為兩塊:

1. 全文檢索。加上分詞(IK 是其中一個)、拼音插件等可以成為強大的全文搜索引擎。

2. 日志統計分析。可以實時動態分析海量日志數據。

二、運行 springboot-elasticsearch 工程

注意的是這里使用的是 ElasticSearch 2.3.2。是因為版本對應關系 :

  • Spring Boot Version (x) Spring Data Elasticsearch Version (y) Elasticsearch Version (z)
  • x <= 1.3.5 y <= 1.3.4 z <= 1.7.2*
  • x >= 1.4.x 2.0.0 <=y < 5.0.0** 2.0.0 <= z < 5.0.0**
  • * - 只需要你修改下對應的 pom 文件版本號
  • ** - 下一個 ES 的版本會有重大的更新

git clone 下載工程 springboot-elasticsearch ,項目地址見 GitHub - https://github.com/JeffLi1993/springboot-learning-example

1. 后臺起守護線程啟動 Elasticsearch

  1. cd elasticsearch-2.3.2/  
  2. ./bin/elasticsearch -d 

下面開始運行工程步驟(Quick Start):

2. 項目結構介紹

  1. org.spring.springboot.controller - Controller 層  
  2. org.spring.springboot.repository - ES 數據操作層  
  3. org.spring.springboot.domain - 實體類  
  4. org.spring.springboot.service - ES 業務邏輯層  
  5. Application - 應用啟動類  
  6. application.properties - 應用配置文件,應用啟動會自動讀取配置 

本地啟動的 ES ,就不需要改配置文件了。如果連測試 ES 服務地址,需要修改相應配置

3.編譯工程

在項目根目錄 springboot-elasticsearch,運行 maven 指令:

  1. mvn clean install 

4.運行工程

右鍵運行 Application 應用啟動類(位置:/springboot-learning-example/springboot-elasticsearch/src/main/java/org/spring/springboot/Application.java)的 main 函數,這樣就成功啟動了 springboot-elasticsearch 案例。

用 Postman 工具新增兩個城市

新增城市信息

  1. POST http://127.0.0.1:8080/api/city 
  2.     "id":"1"
  3.     "provinceid":"1"
  4.     "cityname":"溫嶺"
  5.     "description":"溫嶺是個好城市" 
  1. POST http://127.0.0.1:8080/api/city 
  2.     "id":"2"
  3.     "provinceid":"2"
  4.     "cityname":"溫州"
  5.     "description":"溫州是個熱城市" 

可以打開 ES 可視化工具 head 插件:http://localhost:9200/_plugin/head/

(如果不知道怎么安裝,請查閱

《Elasticsearch 和插件 elasticsearch-head 安裝詳解》。)

在「數據瀏覽」tab,可以查閱到 ES 中數據是否被插入,插入后的數據格式如下:

  1.      "_index""cityindex"
  2.      "_type""city"
  3.      "_id""1"
  4.      "_version": 1, 
  5.      "_score": 1, 
  6.      "_source": { 
  7.           "id": 1, 
  8.           "provinceid": 1, 
  9.           "cityname""溫嶺"
  10.           "description""溫嶺是個好城市" 
  11.      } 

下面驗證下權重分查詢搜索接口的實現:

  1. GET http://localhost:8080/api/city/search?pageNumber=0&pageSize=10&searchContent=溫嶺 

數據是會出現:

  1.   { 
  2.     "id": 1, 
  3.     "provinceid": 1, 
  4.     "cityname""溫嶺"
  5.     "description""溫嶺是個好城市" 
  6.   }, 
  7.   { 
  8.     "id": 2, 
  9.     "provinceid": 2, 
  10.     "cityname""溫州"
  11.     "description""溫州是個熱城市" 
  12.   } 

從啟動后臺 Console 可以看出,打印出來對應的 DSL 語句:

  1.  { 
  2.   "function_score" : { 
  3.     "functions" : [ { 
  4.       "filter" : { 
  5.         "bool" : { 
  6.           "should" : { 
  7.             "match" : { 
  8.               "cityname" : { 
  9.                 "query" : "溫嶺"
  10.                 "type" : "boolean" 
  11.               } 
  12.             } 
  13.           } 
  14.         } 
  15.       }, 
  16.       "weight" : 1000.0 
  17.     }, { 
  18.       "filter" : { 
  19.         "bool" : { 
  20.           "should" : { 
  21.             "match" : { 
  22.               "description" : { 
  23.                 "query" : "溫嶺"
  24.                 "type" : "boolean" 
  25.               } 
  26.             } 
  27.           } 
  28.         } 
  29.       }, 
  30.       "weight" : 100.0 
  31.     } ] 
  32.   } 

為什么會出現 溫州 城市呢?因為 function score query 權重分查詢,無相關的數據默認分值為 1。如果想除去,設置一個 setMinScore 分值即可。

三、springboot-elasticsearch 工程代碼詳解

具體代碼見 GitHub - https://github.com/JeffLi1993/springboot-learning-example

1.pom.xml 依賴

  1. <dependencies> 
  2.  
  3.     <!-- Spring Boot Elasticsearch 依賴 --> 
  4.     <dependency> 
  5.         <groupId>org.springframework.boot</groupId> 
  6.         <artifactId>spring-boot-starter-data-elasticsearch</artifactId> 
  7.     </dependency> 
  8.  
  9.     <!-- Spring Boot Web 依賴 --> 
  10.     <dependency> 
  11.         <groupId>org.springframework.boot</groupId> 
  12.         <artifactId>spring-boot-starter-web</artifactId> 
  13.     </dependency> 
  14.  
  15.     <!-- Junit --> 
  16.     <dependency> 
  17.         <groupId>junit</groupId> 
  18.         <artifactId>junit</artifactId> 
  19.         <version>4.12</version> 
  20.     </dependency> 
  21. </dependencies> 

2. application.properties 配置 ES 地址

  1. # ES 
  2. spring.data.elasticsearch.repositories.enabled = true 
  3. spring.data.elasticsearch.cluster-nodes = 127.0.0.1:9300 

默認 9300 是 Java 客戶端的端口。9200 是支持 Restful HTTP 的接口。

3. ES 數據操作層

  1. @Repository 
  2. public interface CityRepository extends ElasticsearchRepository<City,Long> { 
  3.  

接口只要繼承 ElasticsearchRepository 類即可。默認會提供很多實現,比如 CRUD 和搜索相關的實現。

4. 實體類

  1. @Document(indexName = "cityindex", type = "city"
  2. public class City implements Serializable
  3.  
  4.     private static final long serialVersionUID = -1L; 
  5.  
  6.     /** 
  7.      * 城市編號 
  8.      */ 
  9.     private Long id; 
  10.  
  11.     /** 
  12.      * 省份編號 
  13.      */ 
  14.     private Long provinceid; 
  15.  
  16.     /** 
  17.      * 城市名稱 
  18.      */ 
  19.     private String cityname; 
  20.  
  21.     /** 
  22.      * 描述 
  23.      */ 
  24.     private String description; 

注意

index 配置必須是全部小寫,不然會引出異常:

  1. org.elasticsearch.indices.InvalidIndexNameException: Invalid index name [cityIndex], must be lowercase 

5. ES 業務邏輯層

Service 實現類:

  1. /** 
  2.  * 城市 ES 業務邏輯實現類 
  3.  * 
  4.  * Created by bysocket on 07/02/2017. 
  5.  */ 
  6. @Service 
  7. public class CityESServiceImpl implements CityService { 
  8.  
  9.     private static final Logger LOGGER = LoggerFactory.getLogger(CityESServiceImpl.class); 
  10.  
  11.     @Autowired 
  12.     CityRepository cityRepository; 
  13.  
  14.     @Override 
  15.     public Long saveCity(City city) { 
  16.  
  17.         City cityResult = cityRepository.save(city); 
  18.         return cityResult.getId(); 
  19.     } 
  20.  
  21.     @Override 
  22.     public List<City> searchCity(Integer pageNumber, 
  23.                                  Integer pageSize, 
  24.                                  String searchContent) { 
  25.         // 分頁參數 
  26.         Pageable pageable = new PageRequest(pageNumber, pageSize); 
  27.  
  28.         // Function Score Query 
  29.         FunctionScoreQueryBuilder functionScoreQueryBuilder = QueryBuilders.functionScoreQuery() 
  30.                 .add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("cityname", searchContent)), 
  31.                     ScoreFunctionBuilders.weightFactorFunction(1000)) 
  32.                 .add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("description", searchContent)), 
  33.                         ScoreFunctionBuilders.weightFactorFunction(100)); 
  34.  
  35.         // 創建搜索 DSL 查詢 
  36.         SearchQuery searchQuery = new NativeSearchQueryBuilder() 
  37.                 .withPageable(pageable) 
  38.                 .withQuery(functionScoreQueryBuilder).build(); 
  39.  
  40.         LOGGER.info("\n searchCity(): searchContent [" + searchContent + "] \n DSL  = \n " + searchQuery.getQuery().toString()); 
  41.  
  42.         Page<City> searchPageResults = cityRepository.search(searchQuery); 
  43.         return searchPageResults.getContent(); 
  44.     } 
  45.  

保存邏輯很簡單,這里不解釋了。

分頁 function score query 搜索邏輯:

先創建分頁參數,然后用 FunctionScoreQueryBuilder 定義 Function Score Query,并設置對應字段的權重分值。城市名稱 1000 分,description 100 分。

然后創建該搜索的 DSL 查詢,并打印出來。

四、小結

實際場景還會很復雜。這里只是點睛之筆,后續大家優化或者更改下 DSL 語句就可以完成自己想要的搜索規則。

【本文為51CTO專欄作者“李強強”的原創稿件,轉載請通過51CTO聯系作者獲取授權】

戳這里,看該作者更多好文

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2024-11-11 10:02:37

Spring搜索數據

2022-01-04 19:15:33

ElasticsearSpring BootLogstash

2017-04-17 10:35:40

Spring BooRedis 操作

2022-12-23 08:28:42

策略模式算法

2025-05-09 07:20:02

Spring數據庫檢索

2023-08-02 07:21:30

工具搜索排序

2022-07-21 11:04:53

Swagger3Spring

2017-10-17 15:14:33

Spring BooThymeleafWeb

2022-08-24 08:42:59

Minio存儲Golang

2022-05-30 07:31:38

SpringBoot搜索技巧

2023-10-12 10:32:51

2022-05-06 10:42:09

JavaFlowable引擎

2024-03-26 08:08:08

SpringBPMN模型

2025-06-27 02:44:00

2021-12-27 09:59:57

SpringCanal 中間件

2021-09-16 10:29:05

開發技能代碼

2009-06-18 09:47:50

2023-11-13 12:48:32

語言DSL

2023-10-09 16:35:19

方案Spring支付

2017-05-12 15:47:15

Spring BootMybatis Ann Web
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一本色道精品久久一区二区三区 | 日韩和的一区二在线 | 成人av电影在线观看 | 日韩精品一区二区三区在线播放 | 一区在线播放 | 欧美日韩国产精品一区 | 99久久精品免费看国产免费软件 | 亚洲欧洲精品在线 | 国产一区久久 | 武道仙尊动漫在线观看 | 久久久久久亚洲精品 | 一级片在线视频 | 精品国产乱码久久久久久a丨 | 亚洲黄色片免费观看 | 岛国av免费在线观看 | 国产精品日韩高清伦字幕搜索 | 欧美一级淫片免费视频黄 | 欧美一级片在线看 | 一区二区免费 | 国产欧美精品一区二区色综合朱莉 | 成人亚洲一区 | 一级片片 | 91视频在线 | 玖玖国产| a视频在线观看 | 日韩精品一区二区三区视频播放 | 国产综合精品一区二区三区 | 九九热精品在线 | 国产高清在线精品 | 性精品| 97精品超碰一区二区三区 | 欧美一区二区在线免费观看 | 日韩精品在线视频 | 成人超碰| 久久99精品国产麻豆婷婷 | www.亚洲精品| 日韩成人在线一区 | 91精品国产91久久久久久吃药 | 一二三区在线 | 人人叉| 日韩欧美一级 |