分词解析
{
"111": [
{
"111": "文档",
"start\_offset": 0,
"end\_offset": 2,
"type": "CN\_WORD",
"position": 0
},
{
"111": "数据库",
"start\_offset": 2,
"end\_offset": 5,
"type": "CN\_WORD",
"position": 1
},
{
"111": "数据",
"start\_offset": 2,
"end\_offset": 4,
"type": "CN\_WORD",
"position": 2
},
{
"111": "库",
"start\_offset": 4,
"end\_offset": 5,
"type": "CN\_CHAR",
"position": 3
}
]
}
查询会将分词解析出的分词
ES查询条件 分词查询
http://localhost:9200/fileindex1/_search
{
"query": {
"match": {
"name": "文档数据库"
}
}
}
@Test
void testSearch1() throws IOException {
SearchRequest searchRequest = new SearchRequest("fileindex1");
//构建搜索条件
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
//查询条件,我们可以使用SearchSourceBuilder工具来实现
//精确匹配QueryBuilders.termQuery()
MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("name","测试");
sourceBuilder.query(matchQueryBuilder);
sourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));
searchRequest.source(sourceBuilder);
SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
System.out.println(JSON.toJSONString(searchResponse));
System.out.println("+++++++++++++++++++++++++++++++++++++++++");
for (SearchHit hit : searchResponse.getHits()) {
System.out.println(hit.getSourceAsMap());
}
}
根据具体字段精确查询内容
{
"query": {
"fuzzy": {
"attachment.author.keyword": "测试"
}
}
}
// 根据字段精准查询
@Test
void testSearch3() throws IOException {
SearchRequest searchRequest = new SearchRequest("fileindex1");
//构建搜索条件
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
//查询条件,我们可以使用SearchSourceBuilder工具来实现
//精确匹配QueryBuilders.termQuery()
FuzzyQueryBuilder matchQueryBuilder = QueryBuilders.fuzzyQuery("attachment.author.keyword","user
");
sourceBuilder.query(matchQueryBuilder);
sourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));
searchRequest.source(sourceBuilder);
SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
System.out.println(JSON.toJSONString(searchResponse));
System.out.println("+++++++++++++++++++++++++++++++++++++++++");
for (SearchHit hit : searchResponse.getHits()) {
System.out.println(hit.getSourceAsMap());
}
}
ES 高亮显示查询
http://localhost:9200/fileindex1/_search
{
"query": {
"bool": {
"should": [
{
"match": {
"attachment.author": "NOOB"
}
},
{
"match": {
"attachment.content": "省政府"
}
}
]
}
},
"highlight": {
"fields": {
"attachment.author": {},
"attachment.content": {}
}
}
}
java 实现方式
void testSearch2() throws IOException {
SearchRequest searchRequest = new SearchRequest("fileindex1");
//构建搜索条件
**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**
**深知大多数大数据工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**
**因此收集整理了一份《2024年大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。**
![img](https://img-blog.csdnimg.cn/img_convert/b95bb1030bcb11ce5fc27881be1a51eb.png)
![img](https://img-blog.csdnimg.cn/img_convert/79192fd37e4f5558d2b1b3f10c6f5fbb.png)
![img](https://img-blog.csdnimg.cn/img_convert/a27d1d89fcf325f30a65c059eb9f8182.png)
![img](https://img-blog.csdnimg.cn/img_convert/5bb8ad10c79ac75f26dab979212bb314.png)
![img](https://img-blog.csdnimg.cn/img_convert/867907712b32a9957135f58db6ee6008.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!**
**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
**如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)**
![img](https://img-blog.csdnimg.cn/img_convert/7c8d9bb92e982761c705875759e11302.png)
**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)**
[外链图片转存中...(img-1WgQ2zd2-1712957702878)]
**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**