mirror of
https://github.com/JeffLi1993/springboot-learning-example.git
synced 2026-03-13 21:43:45 +08:00
Spring Boot 整合 Elasticsearch,实现 function score query 权重分查询
This commit is contained in:
2
pom.xml
2
pom.xml
@@ -39,6 +39,8 @@
|
||||
<!-- Spring Boot 整合 Dubbo/ZooKeeper 详解 SOA 案例 -->
|
||||
<module>springboot-dubbo-server</module>
|
||||
<module>springboot-dubbo-client</module>
|
||||
<!-- Spring Boot 整合 Elasticsearch -->
|
||||
<module>springboot-elasticsearch</module>
|
||||
|
||||
</modules>
|
||||
|
||||
|
||||
39
springboot-elasticsearch/pom.xml
Executable file
39
springboot-elasticsearch/pom.xml
Executable file
@@ -0,0 +1,39 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>springboot</groupId>
|
||||
<artifactId>springboot-elasticsearch</artifactId>
|
||||
<version>0.0.1-SNAPSHOT</version>
|
||||
<name>springboot-elasticsearch :: 整合 Elasticsearch </name>
|
||||
|
||||
<!-- Spring Boot 启动父依赖 -->
|
||||
<parent>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-parent</artifactId>
|
||||
<version>1.5.1.RELEASE</version>
|
||||
</parent>
|
||||
|
||||
<dependencies>
|
||||
|
||||
<!-- Spring Boot Elasticsearch 依赖 -->
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Spring Boot Web 依赖 -->
|
||||
<dependency>
|
||||
<groupId>org.springframework.boot</groupId>
|
||||
<artifactId>spring-boot-starter-web</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Junit -->
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>4.12</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
||||
@@ -0,0 +1,20 @@
|
||||
package org.spring.springboot;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
/**
|
||||
* Spring Boot 应用启动类
|
||||
*
|
||||
* Created by bysocket on 16/4/26.
|
||||
*/
|
||||
// Spring Boot 应用的标识
|
||||
@SpringBootApplication
|
||||
public class Application {
|
||||
|
||||
public static void main(String[] args) {
|
||||
// 程序启动入口
|
||||
// 启动嵌入式的 Tomcat 并初始化 Spring 环境及其各 Spring 组件
|
||||
SpringApplication.run(Application.class,args);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,31 @@
|
||||
package org.spring.springboot.controller;
|
||||
|
||||
import org.spring.springboot.domain.City;
|
||||
import org.spring.springboot.service.CityService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.data.domain.Page;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
/**
|
||||
* 城市 Controller 实现 Restful HTTP 服务
|
||||
* <p>
|
||||
* Created by bysocket on 03/05/2017.
|
||||
*/
|
||||
@RestController
|
||||
public class CityRestController {
|
||||
|
||||
@Autowired
|
||||
private CityService cityService;
|
||||
|
||||
@RequestMapping(value = "/api/city", method = RequestMethod.POST)
|
||||
public void createCity(@RequestBody City city) {
|
||||
cityService.saveCity(city);
|
||||
}
|
||||
|
||||
@RequestMapping(value = "/api/city/search", method = RequestMethod.GET)
|
||||
public Page<City> searchCity(@RequestParam(value = "pageNumber") Integer pageNumber,
|
||||
@RequestParam(value = "pageSize", required = false) Integer pageSize,
|
||||
@RequestParam(value = "searchContent") String searchContent) {
|
||||
return cityService.searchCity(pageNumber,pageSize,searchContent);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,69 @@
|
||||
package org.spring.springboot.domain;
|
||||
|
||||
import org.springframework.data.elasticsearch.annotations.Document;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
/**
|
||||
* 城市实体类
|
||||
*
|
||||
* Created by bysocket on 03/05/2017.
|
||||
*/
|
||||
@Document(indexName = "cityIndex", type = "city")
|
||||
public class City {
|
||||
|
||||
// implements Serializable
|
||||
// private static final long serialVersionUID = -1L;
|
||||
|
||||
/**
|
||||
* 城市编号
|
||||
*/
|
||||
private Long id;
|
||||
|
||||
/**
|
||||
* 省份编号
|
||||
*/
|
||||
private Long provinceid;
|
||||
|
||||
/**
|
||||
* 城市名称
|
||||
*/
|
||||
private String cityname;
|
||||
|
||||
/**
|
||||
* 描述
|
||||
*/
|
||||
private String description;
|
||||
|
||||
public Long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public void setId(Long id) {
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
public Long getProvinceid() {
|
||||
return provinceid;
|
||||
}
|
||||
|
||||
public void setProvinceid(Long provinceid) {
|
||||
this.provinceid = provinceid;
|
||||
}
|
||||
|
||||
public String getCityname() {
|
||||
return cityname;
|
||||
}
|
||||
|
||||
public void setCityname(String cityname) {
|
||||
this.cityname = cityname;
|
||||
}
|
||||
|
||||
public String getDescription() {
|
||||
return description;
|
||||
}
|
||||
|
||||
public void setDescription(String description) {
|
||||
this.description = description;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
|
||||
package org.spring.springboot.service;
|
||||
|
||||
import org.spring.springboot.domain.City;
|
||||
import org.springframework.data.domain.Page;
|
||||
|
||||
public interface CityService {
|
||||
|
||||
/**
|
||||
* 新增城市信息
|
||||
*
|
||||
* @param city
|
||||
* @return
|
||||
*/
|
||||
Long saveCity(City city);
|
||||
|
||||
/**
|
||||
* 根据关键词,function score query 权重分分页查询
|
||||
*
|
||||
* @param pageNumber
|
||||
* @param pageSize
|
||||
* @param searchContent
|
||||
* @return
|
||||
*/
|
||||
Page<City> searchCity(Integer pageNumber, Integer pageSize, String searchContent);
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
package org.spring.springboot.service.impl;
|
||||
|
||||
import org.elasticsearch.index.query.QueryBuilders;
|
||||
import org.elasticsearch.index.query.functionscore.FunctionScoreQueryBuilder;
|
||||
import org.elasticsearch.index.query.functionscore.ScoreFunctionBuilders;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.spring.springboot.domain.City;
|
||||
import org.spring.springboot.repository.CityRepository;
|
||||
import org.spring.springboot.service.CityService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.data.domain.Page;
|
||||
import org.springframework.data.domain.PageRequest;
|
||||
import org.springframework.data.domain.Pageable;
|
||||
import org.springframework.data.domain.Sort;
|
||||
import org.springframework.data.elasticsearch.core.query.NativeSearchQueryBuilder;
|
||||
import org.springframework.data.elasticsearch.core.query.SearchQuery;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 城市 ES 业务逻辑实现类
|
||||
*
|
||||
* Created by bysocket on 07/02/2017.
|
||||
*/
|
||||
@Service
|
||||
public class CityServiceImpl implements CityService {
|
||||
|
||||
private static final Logger LOGGER = LoggerFactory.getLogger(CityServiceImpl.class);
|
||||
|
||||
@Autowired
|
||||
CityRepository cityRepository;
|
||||
|
||||
@Override
|
||||
public Long saveCity(City city) {
|
||||
City cityResult = cityRepository.save(city);
|
||||
return cityResult.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Page<City> searchCity(Integer pageNumber,
|
||||
Integer pageSize,
|
||||
String searchContent) {
|
||||
// 分页参数
|
||||
// 按城市编号倒序
|
||||
Pageable pageable = new PageRequest(pageNumber, pageSize, Sort.Direction.DESC, "id");
|
||||
|
||||
// Function Score Query
|
||||
FunctionScoreQueryBuilder functionScoreQueryBuilder = QueryBuilders.functionScoreQuery()
|
||||
.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("cityname", searchContent)),
|
||||
ScoreFunctionBuilders.weightFactorFunction(1000))
|
||||
.add(QueryBuilders.boolQuery().should(QueryBuilders.matchQuery("description", searchContent)),
|
||||
ScoreFunctionBuilders.weightFactorFunction(100));
|
||||
|
||||
// 创建搜索 DSL 查询
|
||||
SearchQuery searchQuery = new NativeSearchQueryBuilder()
|
||||
.withPageable(pageable)
|
||||
.withQuery(functionScoreQueryBuilder).build();
|
||||
|
||||
LOGGER.info("\n searchCity(): searchContent [" + searchContent + "] \n DSL = \n " + searchQuery.getQuery().toString());
|
||||
|
||||
return cityRepository.search(searchQuery);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,3 @@
|
||||
# ES
|
||||
spring.data.elasticsearch.repositories.enabled = true
|
||||
spring.data.elasticsearch.cluster-nodes = 127.0.0.1:9300
|
||||
Reference in New Issue
Block a user