Elasticsearch(十)搜索---搜索匹配功能①--查询所有文档和term级别查询_elasticsearch关系型数据库 搜索(1)

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

public List matchAllQuery(HotelDocRequest hotelDocRequest) throws IOException {
String indexName = hotelDocRequest.getIndexName();
if (CharSequenceUtil.isBlank(indexName)) {
throw new SearchException(“索引名不能为空”);
}
//新建搜索请求
SearchRequest searchRequest = new SearchRequest(indexName);
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
//这里我直接New MatchAllQueryBuilder,不过更推荐QueryBuilders.matchAllQuery().boost(2.0f)
//新建match_all查询,并设置boost值为2.0
searchSourceBuilder.query(new MatchAllQueryBuilder().boost(2.0f));
searchRequest.source(searchSourceBuilder);
return getQueryResult(searchRequest);
}


在controller层调用service:



@PostMapping("/query/match\_all")
public FoundationResponse<List<Hotel>> matchAllQuery(@RequestBody HotelDocRequest hotelDocRequest) {
	try {
		List<Hotel> hotelList = esQueryService.matchAllQuery(hotelDocRequest);
		if (CollUtil.isNotEmpty(hotelList)) {
			return FoundationResponse.success(hotelList);
		} else {
			return FoundationResponse.error(100,"no data");
		}
	} catch (IOException e) {
		log.warn("搜索发生异常,原因为:{}", e.getMessage());
		return FoundationResponse.error(100, e.getMessage());
	} catch (Exception e) {
		log.error("服务发生异常,原因为:{}", e.getMessage());
		return FoundationResponse.error(100, e.getMessage());
	}
}

postman调用该接口:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/cd5e82f869254a5883895881ba34ec0c.png)


## 三、term级别查询


### 3.1、term查询


term查询是结构化精准查询的主要查询方式,用于查询待查字段和查询值是否完全匹配,其请求形式如下:



GET /hotel/_search
{
“query”: {
“term”: {
KaTeX parse error: Expected '}', got 'EOF' at end of input: … "value": "{VALUE}” //搜索值
}
}
}
}


其中,FIELD和VALUE分别代表字段名称和查询值,FIELD的数据类型可以是**数值型,布尔型、日期型、数组型及关键字**等。  
 例如,下面的例子是查找city为北京的酒店,DSL如下:



GET /hotel/_search
{
“_source”: [“title”,“city”], //希望返回的结果字段
“from”: 0, //分页
“size”: 10001,
“query”: {
“term”: {
“city”: { //搜索字段是city,字段类型为keyword
“value”: “北京”
}
}
}
}


返回结果如下:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/58960de4ee654742b06f9b4289b74eb5.png)  
 对于日期型的字段查询,需要按照该字段在mappings中定义的格式进行查询。如果格式不对,那么请求将报错:  
 例如我这边create\_time的格式是yyyy-MM-dd HH:mm:ss  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/2301a12655ec4cf7b37af4bcfb1ed87e.png)  
 如果我拿其他格式进行请求:



GET /hotel/_search
{
“_source”: [“title”,“city”],
“query”: {
“term”: {
“create_time”: {
“value”: “20230121142456”
}
}
}
}


会发现报错  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/f3d06c00cbaf46db97be9f68fd0ef0de.png)  
 在java客户端中进行查询时,可以调用`QueryBuilders.termQuery()`方法新建一个term查询,可以传入boolean、double、float、int、long和String等类型的参数,但是没有日期类型的参数,如下图所示:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/a2c671ee9ba44324a5d98a75791bc1f1.png)  
 那么如何构建日期类型的term查询呢?可以使用日期格式字符串类型的term查询来解决。以下为使用日期类型的字符串参数构建的term查询:我们传参一般是date类型,这个时候我们将传过来的fate类型通过simpleDateFormat对传参的date进行转化,即可顺利进行查询。



public List<Hotel> getCityByCreateTime(HotelDocRequest hotelDocRequest) throws IOException {
	String indexName = hotelDocRequest.getIndexName();
	if (CharSequenceUtil.isBlank(indexName)) {
		throw new SearchException("索引名不能为空");
	}
	Hotel hotel = hotelDocRequest.getHotel();
	if (ObjectUtil.isEmpty(hotel)) {
		throw new SearchException("搜索条件不能为空");
	}
	SearchRequest searchRequest = new SearchRequest(indexName);
	//创建搜索builder
	SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
	//构建query
	String createTimeToSearch = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format( hotel.getCreateTime());
	searchSourceBuilder.query(QueryBuilders.termQuery("create\_time",createTimeToSearch));
	//设定希望返回的字段数组
	searchRequest.source(searchSourceBuilder); //设置查询
	return getQueryResult(searchRequest);
}

以下是postman调用例子  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/c458638ab3594cce98dee2a252d7b928.png)


3.2、terms查询  
 terms查询是term查询的扩展形式,,用于查询一个或多个值与待查字段是否完全匹配,请求形式如下:



GET /hotel/_search
{
“query”: {
“terms”: {
“FIELD”: [
“VALUE1”,
“VALUE2”
]

}

}
}


其中,FIEKD代表待查字段名,VALUE1和VALUE2代表多个查询值,FIELD的数据类型可以是数值型,布尔型,日期型,数组型及关键字等。  
 以下是搜索城市为北京或者上海的酒店示例:



GET /hotel/_search
{
“_source”: [“title”,“city”],
“from”: 0,
“size”: 10001,
“query”: {
“terms”: {
“city”: [
“北京”,
“上海”
]

}

}
}


![在这里插入图片描述](https://img-blog.csdnimg.cn/681a9b6e80bc43db880e20be111f83d0.png)  
 在java客户端中对应terms查询的类为`TermsQuery`,该类的实例通过`QueryBuilders.termsQuery()`生成。在`QueryBuilders.termsQuery()`方法中,第一个参数为字段名称,第二个参数是一个集合类型,也可以是一个单独类型,当为单独类型时,该参数为可变长度参数。`QueryBuilders.termsQuery()`方法列表如下图:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/e225a94a3a124953987d54ead9957ec6.png)  
 以下是使用java进行terms查询城市为北京或者上海的酒店示例:  
 Service层,我们接收一个citys数组参数



public List<Hotel> termsQuery(HotelDocRequest hotelDocRequest) throws IOException {
	//新建搜索请求
	String indexName = hotelDocRequest.getIndexName();
	if (CharSequenceUtil.isBlank(indexName)) {
		throw new SearchException("索引名不能为空");
	}
	SearchRequest searchRequest = new SearchRequest(indexName);
	SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
	List<String> cities = hotelDocRequest.getCities();
	searchSourceBuilder.query(QueryBuilders.termsQuery("city", cities));
	searchRequest.source(searchSourceBuilder);
	return getQueryResult(searchRequest);
}

controller层:


![img](https://img-blog.csdnimg.cn/img_convert/590f5ebdef56e072a2bc4872cd4439e0.png)
![img](https://img-blog.csdnimg.cn/img_convert/9c26b944016f7b5033aa18ef1e191fc8.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

1)]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 16
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值