1.spring已集成了elasticSearch的搜索API
<dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-elasticsearch</artifactId> <version>3.2.0.RELEASE</version> </dependency> |
---|
2.yml文件中配置ES库的地址和密码
spring: data: elasticsearch: cluster-name: elasticsearch cluster-nodes: 172.16.17.230:9300 repositories: enabled: true |
---|
3.在es-service可以直接注入使用:
@Resource private ElasticsearchTemplate elasticsearchTemplate; |
---|
4.查询参数准备:
SearchQuery query; 用于封装查询条件 Class<T> clazz; 用于接收查询结果的实体对象 |
---|
5.执行查询:
AggregatedPage<T> ts = elasticsearchTemplate.queryForPage(query, clazz); //分页查询 会返回总记录数 List<T> tList = elasticsearchTemplate.queryForList(query, clazz); //不分页查询 返回结果列表 |
---|
重点一:query参数的拼装 以SearchQuery的实现类NativeSearchQuery为例:
SearchQuery query = new NativeSearchQueryBuilder() .withQuery( QueryBuilders.boolQuery() //声明要一个布尔类型的结果 类似where //must相当于and ,matchQuery代表参数分词后进行筛选 .must(QueryBuilders.matchQuery(fieldName,fieldValue)) // matchPhraseQuery 支持一个搜索参数匹配多个字段 .must(QueryBuilders.matchPhraseQuery(keyword, keywordFields)); // should相当于or ,termQuery代表参数不分词进行筛选 fieldValue可以传数组(termsQuery),代替SQL中的 in .should(QueryBuilders.termQuery(fieldName,fieldValue)) ) .withPageable(PageRequest.of(pageNum, pageSize)) //分页配置 .build(); |
---|
Class<T> clazz = TestClass.class; 实体类想要接收ES的查询结果,需要配置注解 在实体类上加上 :@org.springframework.data.elasticsearch.annotations.Document(indexName = "indexName", type = "_doc") 如果ES的mapping字段名与实体类属性名不一致,可在实体类属性上加@JsonProperty("ES mapping 字段名") 设置别名。 |
重点二:termQuery 和 matchQuery
termQuery : 精确查询,直接拿查询条件去匹配 matchQuery:分词查询,将查询条件进行分词,然后拿分词后的结果去匹配。 |
---|
重点三:精准匹配时用数字分词机制
当库中的数据有汉字或者查询条件是汉字时,ES会对汉字进行分词,容易造成查询结果不够精确。 而连续的数字字符串会被当成一个词,不会被细分更小单元。 举例说明: ES数据: tag_name : "王者荣耀 活动" 查询关键字:王者荣耀 此时是无法匹配到ES中的数据的,而查询 “王者” 或者 查询 “荣耀” 可以匹配到(查询结果不精准)。 解决办法:将标签中存储的标签转化成数字id,ES的数据变成了 tag_name: "411 25" 查询条件 : 411 此时可以匹配到ES的数据。 使用连续英文也可以。 |
---|
1.spring已集成了elasticSearch的搜索API
<dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-elasticsearch</artifactId> <version>3.2.0.RELEASE</version> </dependency> |
---|
2.yml文件中配置ES库的地址和密码
spring: data: elasticsearch: cluster-name: elasticsearch cluster-nodes: 172.16.17.230:9300 repositories: enabled: true |
---|
3.在es-service可以直接注入使用:
@Resource private ElasticsearchTemplate elasticsearchTemplate; |
---|
4.查询参数准备:
SearchQuery query; 用于封装查询条件 Class<T> clazz; 用于接收查询结果的实体对象 |
---|
5.执行查询:
AggregatedPage<T> ts = elasticsearchTemplate.queryForPage(query, clazz); //分页查询 会返回总记录数 List<T> tList = elasticsearchTemplate.queryForList(query, clazz); //不分页查询 返回结果列表 |
---|
重点一:query参数的拼装 以SearchQuery的实现类NativeSearchQuery为例:
SearchQuery query = new NativeSearchQueryBuilder() .withQuery( QueryBuilders.boolQuery() //声明要一个布尔类型的结果 类似where //must相当于and ,matchQuery代表参数分词后进行筛选 .must(QueryBuilders.matchQuery(fieldName,fieldValue)) // matchPhraseQuery 支持一个搜索参数匹配多个字段 .must(QueryBuilders.matchPhraseQuery(keyword, keywordFields)); // should相当于or ,termQuery代表参数不分词进行筛选 fieldValue可以传数组(termsQuery),代替SQL中的 in .should(QueryBuilders.termQuery(fieldName,fieldValue)) ) .withPageable(PageRequest.of(pageNum, pageSize)) //分页配置 .build(); |
---|
Class<T> clazz = TestClass.class; 实体类想要接收ES的查询结果,需要配置注解 在实体类上加上 :@org.springframework.data.elasticsearch.annotations.Document(indexName = "indexName", type = "_doc") 如果ES的mapping字段名与实体类属性名不一致,可在实体类属性上加@JsonProperty("ES mapping 字段名") 设置别名。 |
重点二:termQuery 和 matchQuery
termQuery : 精确查询,直接拿查询条件去匹配 matchQuery:分词查询,将查询条件进行分词,然后拿分词后的结果去匹配。 |
---|
重点三:精准匹配时用数字分词机制
当库中的数据有汉字或者查询条件是汉字时,ES会对汉字进行分词,容易造成查询结果不够精确。 而连续的数字字符串会被当成一个词,不会被细分更小单元。 举例说明: ES数据: tag_name : "王者荣耀 活动" 查询关键字:王者荣耀 此时是无法匹配到ES中的数据的,而查询 “王者” 或者 查询 “荣耀” 可以匹配到(查询结果不精准)。 解决办法:将标签中存储的标签转化成数字id,ES的数据变成了 tag_name: "411 25" 查询条件 : 411 此时可以匹配到ES的数据。 使用连续英文也可以。 |
---|