国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

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專欄
相關推薦

2025-07-02 07:33:02

Spring倒排索引分布式

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

工具搜索排序

2017-10-17 15:14:33

Spring BooThymeleafWeb

2022-07-21 11:04:53

Swagger3Spring

2025-11-21 08:08:57

2022-08-24 08:42:59

Minio存儲Golang

2022-05-30 07:31:38

SpringBoot搜索技巧

2025-09-23 08:00:52

SpringApache文件類型

2023-10-12 10:32:51

2025-06-27 02:44:00

2024-03-26 08:08:08

SpringBPMN模型

2022-05-06 10:42:09

JavaFlowable引擎

2021-12-27 09:59:57

SpringCanal 中間件

2009-06-18 09:47:50

2021-09-16 10:29:05

開發技能代碼
點贊
收藏

51CTO技術棧公眾號

国产黄在线播放| 麻豆蜜桃在线观看| 一区二区三区伦理| 久久一区中文字幕| 亚洲福利在线播放| 久久婷婷综合色| 久久网这里都是精品| 国产精品久久久久久久久影视 | 国产精品毛片av| 国产在线麻豆精品观看| 日韩中文在线中文网三级| 超碰在线免费公开| 欧美日韩精品在线播放| 成人免费观看视频在线观看| 欧美性生活一级片| 欧美不卡一区二区三区四区| 日韩国产一级片| 中文久久电影小说| 欧美日韩激情一区二区三区| 成人激情电影一区二区| 视频一区二区在线| 久久爱91午夜羞羞| 国产亚洲一区字幕| 99久久精品免费看国产一区二区三区 | 欧美日韩国产精品一区二区| 第四色婷婷基地| 成人盗摄视频| 91久久香蕉国产日韩欧美9色| 国产日韩在线亚洲字幕中文| 你懂的在线观看视频网站| 2023国产精品久久久精品双| 欧美网站大全在线观看| 精品国产免费人成电影在线观...| 天堂视频福利| 亚洲国产电影| 日韩av在线看| 成人一区二区三| 国产精品亚洲一区二区在线观看| 国产在线精品视频| 亚洲视频在线免费观看| eeuss在线观看| 亚洲免费视频在线观看| 亚洲高清免费视频| 国产99久久精品一区二区永久免费| av在线无限看| 蜜桃视频在线一区| 91chinesevideo永久地址| 国产91福利| 奇米色一区二区| 欧美精品videos| 99热在线看| 亚洲色图网站| 亚洲精品久久久久中文字幕二区| 成人观看网站a| 天天综合精品| 美日韩在线视频| 黄黄的网站在线观看| 午夜视频免费在线观看| 999久久久精品国产| 日韩三级精品电影久久久| 草b视频在线观看| 91精品精品| 污污的网站18| 第一福利在线| 九九九九九精品| 精品一区二区三区在线播放| 女女百合国产免费网站| 中文字幕二三区不卡| 日本不卡在线| 久久精品视频在线观看| 国产精品成人a在线观看| 91久久中文字幕| 2021国产精品久久精品| 在线观看免费黄视频| 欧美精品久久久久久久| 久久99精品国产.久久久久久| 亚洲成人av高清| 久久在线免费观看视频| 自拍视频在线观看一区二区| 亚洲男人资源| 日韩av一区在线| 免费久久精品| 国产精品影视| 2019中文在线观看| 亚洲欧美另类图片小说| 九热爱视频精品视频| 16—17女人毛片毛片| 国产va免费精品高清在线观看| 国产精品久久久久天堂| 日韩在线免费| 成人在线观看毛片| 亚洲精品国产免费| 国产精品123| 亚洲国产欧美国产第一区| 日韩一区二区三区久久| 亚洲欧美国产精品专区久久| 激情五月播播久久久精品| 国产亚洲人成a在线v网站| 在线天堂一区av电影| 成人免费在线观看| 精品视频在线看| 久久久久久成人精品| 欧美一区网站| 国产成人亚洲精品无码h在线| 欧洲中文字幕精品| 亚洲tv在线| 日韩电影免费观看高清完整| 欧美成人激情在线| 中文无码久久精品| 美女一区二区三区视频| 神马久久桃色视频| 亚洲色图.com| 91精品亚洲一区在线观看| 国产精品综合不卡av| 色婷婷精品大在线视频| 福利一区和二区| 国产一级精品aaaaa看| 日韩一区二区免费在线观看| 成人中文在线| 中文字幕第36页| 亚洲最新av在线| 日本不卡高清视频| 1pondo在线播放免费| 国产精品久在线观看| 中文久久乱码一区二区| 99精品女人在线观看免费视频 | 色七七在线观看| 国产亚洲欧洲高清| 国产中文字幕精品| 99久久精品免费看国产小宝寻花| 久久香蕉综合色| 91精品国产黑色紧身裤美女| 一区二区日韩免费看| 欧美激情办公室videoshd| 久久国产一区二区| 欧美日韩国产片| 久久久综合网| 小视频免费在线观看| 国产美女主播在线播放| 中文字幕日韩高清| www国产精品av| 日韩成人在线观看视频| 色国产在线视频| 国产成人综合精品| 色综合天天综合网天天看片| 欧美精品91| 一色桃子av在线| 黄色一级视频播放| 在线观看日韩欧美| 欧美国产一区在线| 欧美电影一区| 亚洲七七久久综合桃花剧情介绍| 一区视频二区视频| 美女视频黄免费的亚洲男人天堂| 久久久久久久综合色一本| 国产精品巨作av| 在线免费视频你懂得| 国产一区精品视频| 日韩成人在线视频网站| www.欧美色图| 中文字幕精品影院| 日韩精品成人av| 免费看日b视频| 国内外成人免费激情在线视频网站| 一区二区三区日韩精品| 91免费精品| 精品综合久久久久久8888| 国产91精品露脸国语对白| 蜜臀精品一区二区三区在线观看| 91精品福利视频| 日本女优在线视频一区二区| jizz亚洲女人高潮大叫| 欧美男同性恋视频网站| 亚洲香蕉av在线一区二区三区| 欧美视频在线观看一区二区| 成人在线视频亚洲| 影音欧美亚洲| 久久久久久久久久久免费| 狠狠爱在线视频一区| 久久99热99| 香蕉视频一区二区三区| 自拍视频在线网| 久草免费福利在线| 国产美女精品视频免费观看| 亚洲第一精品福利| 亚洲视频你懂的| 日韩av一区二区在线影视| 一区二区三区免费在线看| 国产视频精品久久| 女人喷潮完整视频| 91在线中文字幕| 日韩中文字幕免费| 91福利视频网站| 972aa.com艺术欧美| 欧美日韩三级| 4438全国亚洲精品观看视频| 91国内在线| 最近中文字幕2019第二页视频| 久久涩涩网站| 欧洲s码亚洲m码精品一区|