1、添加ES依赖
<!--es-client-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
2、添加ES配置
spring:
data:
elasticsearch:
client:
reactive:
endpoints: 10.140.188.135:9200 #es服务器地址
username: elastic #用户名
password: 123456 #访问密码
elasticsearch:
rest:
uris: 10.140.188.135:9200 #es服务器地址
username: elastic #用户名
password: 123456 #访问密码
3、添加Entity(indexName为索引名称,type为类型名称)
@Data
@Accessors(chain = true)
@Document(indexName = "article", type = "_doc")
public class Article {
private String id;
private String content;
private String title;
private String keywords;
@DateTimeFormat(pattern = "yyyy-MM-dd")
@JsonFormat(pattern = "yyyy-MM-dd")
private Date update_time;
}
上面代码的type的值要注意,是类型名称,在源码中拼接在索引后面,如下图所示:

4、添加Service
public interface ArticleService extends ElasticsearchRepository<Article,String> {
/**
* match查询
* @param title
* @return
*/
@Query("{\"match\": {\"title\":\"?0\"}}")
List<Article> findByTitle(String title);
/**
* match查询 - 分页
* @param title
* @param pageable
* @return
*/
@Query("{\"match\": {\"title\":\"?0\"}}")
Page<Article> findByTitlePage(String title,Pageable pageable);
}
5、查询说明
在controller中定义对象:
private final ArticleService articleService;
public TestController(ArticleService articleService) {
this.articleService = articleService;
}
查询单条数据:
@GetMapping()
public Result getData(){
Optional<Article> article = this.articleService.findById("1");
return Result.ok().data("article",article);
}
自定义查询,以分页查询举例:
@GetMapping("searchpage")
public Result searchPage(@RequestParam(value = "title",required = true) String title){
PageRequest pageRequest = PageRequest.of(0,10);
Page<Article> articles = this.articleService.findByTitlePage(title,pageRequest);
return Result.ok().data("article",articles);
}
本文介绍如何在Spring Boot项目中集成Elasticsearch,包括添加依赖、配置ES服务器、创建实体类、定义Service接口及实现自定义查询等功能。

245

被折叠的 条评论
为什么被折叠?



