- 浏览: 693735 次
- 性别:
- 来自: 长沙
文章分类
- 全部博客 (364)
- quick start (57)
- bboss aop (43)
- bboss mvc (48)
- bboss persistent (96)
- bboss taglib (30)
- bboss event (10)
- bbossgroups (52)
- bboss (32)
- bboss会话共享 (17)
- bboss rpc (7)
- bboss 国际化 (5)
- bboss 序列化 (9)
- bboss cxf webservice (8)
- bboss hessian (3)
- bboss 安全认证SSO (15)
- bboss 工作流 (6)
- 平台 (18)
- bboss quartz (3)
- 杂谈 (5)
- 大数据 (1)
- bboss elastic (24)
- bboss http (1)
- bboss kafka (1)
- Elasticsearch Scroll和Slice Scroll查询API使用案例 (1)
最新评论
-
qianhao123:
...
采用gradle构建和发布bboss方法介绍 -
qianhao123:
[img][/img]
采用gradle构建和发布bboss方法介绍 -
yin_bp:
欢迎大家参与working
高性能elasticsearch ORM开发库使用介绍 -
qq641879434:
万分感谢
bboss 持久层sql xml配置文件编写和加载方法介绍 -
yin_bp:
qq641879434 写道怎么设置配置文件 可以查看执行的S ...
bboss 持久层sql xml配置文件编写和加载方法介绍
1.前期准备
参考文档《高性能elasticsearch ORM开发库使用介绍》导入和配置es客户端bboss
2.mget操作
简单而直观的多文档获取案例
通过执行dsl获取多个文档的内容案例
dsl定义-esmapper/estrace/mget.xml
3.更新索引文档部分信息案例
简单api案例
采用dsl案例
dsl文件定义-esmapper/agentstat.xml
4.GetDocSource案例
5.几种经典的获取文档数据案例
根据文档id获取
根据rest url获取
更多bboss 使用文档可以参考:
https://my.oschina.net/bboss/blog/1556866
参考文档《高性能elasticsearch ORM开发库使用介绍》导入和配置es客户端bboss
2.mget操作
简单而直观的多文档获取案例
ClientInterface clientUtil = ElasticSearchHelper.getRestClientUtil(); //获取json报文 String response = clientUtil.mgetDocuments("agentinfo",//索引表 "agentinfo",//索引表类型 "10.21.20.168","192.168.0.143");//文档id清单 System.out.println(response); //获取封装成对象的文档列表,此处是Map对象,还可以是其他用户定义的对象类型 List<Map> docs = clientUtil.mgetDocuments("agentinfo",//索引表 "agentinfo",//索引表类型 Map.class,//返回文档对象类型 "10.21.20.168","192.168.0.143");//文档id清单 System.out.println(docs);
通过执行dsl获取多个文档的内容案例
ClientInterface clientUtil = ElasticSearchHelper.getConfigRestClientUtil("esmapper/estrace/mget.xml"); //通过执行dsl获取多个文档的内容,具体可以参考文档: //https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-multi-get.html List<String> ids = new ArrayList<String>(); ids.add("10.21.20.168"); ids.add("192.168.0.143"); Map params = new HashMap(); params.put("ids",ids); String response = clientUtil.executeHttp("_mget", "testMget",//dsl定义名称 params, //存放文档id的参数 ClientUtil.HTTP_POST); System.out.println(response); List<Map> docs = clientUtil.mgetDocuments("_mget", "testMget",//dsl定义名称 params, //存放文档id的参数 Map.class);//返回文档对象类型 System.out.println(docs);
dsl定义-esmapper/estrace/mget.xml
<!-- GET /_mget { "docs" : [ { "_index" : "agentinfo", "_type" : "agentinfo", "_id" : "10.21.20.168" }, { "_index" : "agentinfo", "_type" : "agentinfo", "_id" : "192.168.0.143" } ] } --> <property name="testMget"> <![CDATA[ { "docs" : [ #foreach($id in $ids) #if($velocityCount > 0),#end { "_index" : "agentinfo", "_type" : "agentinfo", "_id" : "$id" } #end ] } ]]> </property>
3.更新索引文档部分信息案例
简单api案例
Map params = new HashMap(); Date date = new Date(); params.put("eventTimestamp",date.getTime()); params.put("eventTimestampDate",date); /** * 更新索引部分内容 */ ClientInterface restClientUtil = ElasticSearchHelper.getRestClientUtil(); String response = restClientUtil.updateDocument("agentinfo",//索引表名称 "agentinfo",//索引type "pdpagent",//索引id params,//待更新的索引字段信息 "refresh");//强制刷新索引 System.out.println(response);
采用dsl案例
ClientInterface configRestClientUtil = ElasticSearchHelper.getConfigRestClientUtil("esmapper/agentstat.xml"); Map params = new HashMap(); Date date = new Date(); params.put("eventTimestamp",date.getTime()); params.put("eventTimestampDate",date); /** * 采用dsl更新索引部分内容,dsl定义和路径api可以参考文档: * https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-update.html */ StringBuilder path = new StringBuilder(); path.append("agentinfo/agentinfo/pdpagent/_update?refresh");//自行拼接rest api地址 configRestClientUtil.updateByPath(path.toString(), "updateAgentInfoEndtime",//更新文档内容的dsl配置名称 params);
dsl文件定义-esmapper/agentstat.xml
<properties> <!-- POST test/_doc/1/_update { "doc" : { "name" : "new_name" } } --> <property name="updateAgentInfoEndtime"> <![CDATA[ { "doc" : { "endTimestamp" : #[eventTimestamp], "endTimestampDate" : #[eventTimestampDate] } } ]]> </property> </properties>
4.GetDocSource案例
ClientInterface clientUtil = ElasticSearchHelper.getRestClientUtil(); //获取json报文索引source,不返回索引元数据 String response = clientUtil.getDocumentSource("agentinfo/agentinfo/10.21.20.168/_source"); System.out.println(response); //获取对象类型source,此处对象类型是map,可以指定自定义的对象类型,不返回索引元数据 Map data = clientUtil.getDocumentSource("agentinfo/agentinfo/10.21.20.168/_source",Map.class); System.out.println(data); //请求地址格式说明: // index/indexType/docId/_source // 实例如下: // "agentinfo/agentinfo/10.21.20.168/_source"
5.几种经典的获取文档数据案例
根据文档id获取
//根据文档id获取文档对象,返回json报文字符串 String response = clientUtil.getDocument("demo",//索引表 "demo",//索引类型 "2");//w System.out.println("打印结果:getDocument-------------------------"); System.out.println(response); //根据文档id获取文档对象,返回Demo对象 demo = clientUtil.getDocument("demo",//索引表 "demo",//索引类型 "2",//文档id Demo.class);
根据rest url获取
ClientInterface clientUtil = ElasticSearchHelper.getRestClientUtil(); String response = clientUtil.getDocumentByPath("agentinfo/agentinfo/10.21.20.168"); System.out.println(response); Map data = clientUtil.getDocumentByPath("agentinfo/agentinfo/10.21.20.168",Map.class); System.out.println(data); //请求地址格式说明: // index/indexType/docId // 实例如下: // "agentinfo/agentinfo/10.21.20.168"
更多bboss 使用文档可以参考:
https://my.oschina.net/bboss/blog/1556866
发表评论
-
一组获取Elasticsearch 索引表所有文档API使用案例
2018-11-18 16:02 3147The best elasticsearch highle ... -
Elasticsearch Scroll和Slice Scroll查询API使用案例
2018-09-16 18:49 3969Elasticsearch Scroll和Slice Scro ... -
数据库数据导入Elasticsearch案例分享
2018-09-16 18:42 6386The best elasticsearch highleve ... -
Spring Boot整合ElasticSearch单/多集群案例
2018-07-07 20:12 9946Spring Boot整合ElasticSearch单个集群和 ... -
ElasticSearch DSL Script使用案例分享
2018-06-28 23:52 6312the best elasticsearch highleve ... -
Elasticsearch 6.3.0 SQL功能使用案例分享
2018-06-25 19:12 3382The best elasticsearch highleve ... -
数据库数据导入Elasticsearch案例分享
2018-06-21 22:56 433The best elasticsearch highleve ... -
ElasticSearch From-Size分页案例
2018-06-14 00:17 3488ElasticSearch From-Size分页案例 1. ... -
ElasticSearch客户端注解使用介绍
2018-05-30 00:19 2504The best elasticsearch highleve ... -
基于自定义配置文件初始化ElasticSearch客户端方法介绍
2018-05-24 18:56 1570基于自定义配置文件初始化ElasticSearch客户端方法介 ... -
Elasticsearch关键词高亮检索案例分享
2018-05-10 22:18 62821.准备工作 参考文档《集成Elasticsearch Res ... -
判断ElasticSearch索引Indice和索引类型是否存在
2018-05-05 23:54 8592The best elasticsearch highleve ... -
快速集成Elasticsearch Restful API案例
2018-04-26 14:27 3245The best elasticsearch highleve ... -
Elasticsearch source filter检索案例
2018-04-24 13:00 2335摘要: the best elasticsearch high ... -
Elasticsearch search after分页检索案例
2018-04-21 10:36 3184Elasticsearch search after分页检索案 ... -
Elasticsearch Delete/UpdateByQuery案例
2018-04-16 11:09 7472Elasticsearch Delete/UpdateByQu ... -
Elasticsearch返回父子数据关联查询案例
2018-04-13 12:36 4794在《Elasticsearch 父子关 ... -
Elasticsearch Sliced Scroll分页检索案例分享
2018-04-02 18:28 3831Elasticsearch Sliced Scroll分页检索 ... -
Elasticsearch地理位置维护及检索案例分享
2018-03-31 21:36 1739Elasticsearch地理位置信息维护及检索案例分享 1 ... -
Elasticsearch Scroll分页检索案例分享
2018-03-28 20:40 4125Elasticsearch Scroll分页检索案例分享 1 ...
相关推荐
elasticsearch 同义词创建索引实例
首先,Elasticsearch的索引创建通常通过JSON格式的文件来定义,如示例中的`Elasticsearch 添加索引`部分所示。这个文件包含了索引的设置(settings)和映射(mappings)。 1. **设置(Settings)**: - `"number_...
**Elasticsearch 7.0 备份索引脚本详解** 在大数据分析和日志管理领域,Elasticsearch(ES)是一个广泛使用的开源搜索引擎和分析引擎。它提供了实时、可扩展的搜索和分析功能。然而,数据的安全性和可靠性至关重要...
通过使用Spring Data Elasticsearch,我们可以方便地实现Elasticsearch的CRUD(创建、读取、更新和删除)操作。 1. **单个的增删改查**: 在Spring Boot应用中,我们可以通过定义Repository接口并继承`...
在IT行业中,日志管理是系统维护和故障排查的关键环节,而Elasticsearch(简称ES)作为一款强大的全文搜索引擎,常被用来存储和分析大量日志数据。然而,随着日积月累,这些数据可能会变得非常庞大,如果不进行有效...
Elasticsearch-深入理解索引原理 Elasticsearch 中索引(Index)的概念是非常重要的,它是 Elasticsearch 存储数据的基本单元。索引是一个具有类似特性的文档的集合,类比传统的关系型数据库领域来说,索引相当于 ...
Elasticsearch(ES)是一种基于Lucene的分布式、RESTful搜索和分析引擎,广泛用于大数据的实时分析和检索。在本讲座中,我们将深入探讨Elasticsearch中的索引概念及其重要性。 首先,让我们理解一下ES中的“索引”...
1. **Elasticsearch基础**:Elasticsearch(ES)是一个开源的、分布式全文搜索引擎,它提供了实时数据分析的能力,广泛用于日志分析、监控、搜索应用等领域。其核心特性包括分布式、RESTful接口、实时性、可扩展性和...
**Elasticsearch官方提供数据案例account.json** Elasticsearch是一个高度可扩展的开源全文搜索和分析引擎,它允许用户快速地存储、搜索和分析大量数据。在这个案例中,"account.json"是Elasticsearch官方提供的一...
**Elasticsearch与MySQL热更新IK词典项目详解** 在现代大数据检索和分析场景中,Elasticsearch(ES)作为一款强大的开源搜索引擎,被广泛应用于日志分析、全文搜索等领域。而IK(Intelligent Chinese)分词器是针对...
索引插件是Elasticsearch生态系统中的重要组成部分,它们扩展了Elasticsearch的功能,提供了更多管理和操作索引的便利性。"plugin-head"是其中一款知名的插件,主要用于提供一个直观的Web界面,帮助用户更轻松地管理...
在本文中,我们将深入探讨如何使用Spring Boot与Elasticsearch 7.6.2进行基本操作,包括创建索引、添加数据以及查询数据。Elasticsearch是一个强大的分布式搜索引擎,而Spring Boot是Java开发中的轻量级框架,两者...
Elasticsearch查询客户端是用于与ES服务器通信的软件,它们提供了多种语言的API,允许开发者以编程方式执行索引、搜索、更新和删除等操作。常见的Elasticsearch客户端包括: - **Jest**:一个轻量级的Java REST...
### 彻底清理:如何安全删除 Elasticsearch 中的索引 Elasticsearch 是一款基于 Lucene 构建的开源、分布式、RESTful 风格的搜索与分析引擎,广泛应用于处理大规模数据集的搜索、分析及存储场景。其显著特点包括...
在深入理解Elasticsearch(简称ES)的索引原理前,我们需要先明白基本概念。ES是一种分布式全文搜索引擎,它将数据存储在索引中,这些索引类似于关系型数据库中的数据库,但具备更高的可扩展性和实时性。索引可以...
lasticsearch整合分词、创建索引、搜索例子,elasticsearch版本为1.0,索引数据从数据表中动态读取生成,有关键字高亮效果,查询分页 1 在dababase目录中导致相关的数据库文件,修改DBCOperation java文件数据库连接...
多弹性搜索头,对著名的 Elasticsearch Head 的改进 1.保存和存储几个Elasticsearch端点 ...它通常提供了一种直观的方式来查看索引结构、执行查询语句、分析日志数据,以及执行其他与Elasticsearch管理相关的任务。
(狂神)ElasticSearch快速入门笔记,ElasticSearch基本操作以及爬虫(Java-ES仿京东实战),包含了小狂神讲的东西,特别适合新手学习,笔记保存下来可以多看看。好记性不如烂笔头哦~,ElasticSearch,简称es,es是一个...
在7.17.5版本中,针对同义词热更新的需求,Elasticsearch提供了相应的插件,以提高系统的灵活性和实时性。这个插件允许用户在不重启服务的情况下,对同义词库进行动态更新,这对于那些需要频繁调整同义词表的应用...