1.创建索引并插入数据
Map<String, Object> json = new HashMap<String, Object>();
json.put("user", "kimchy5");
json.put("postDate", new Date());
json.put("message", "trying out Elasticsearch");
//参数设置
//Settings settings = Settings.settingsBuilder().put("cluster.name", "elasticsearch").build();
//TransportClient client = TransportClient.builder().settings(settings).build();
Client client = TransportClient.builder().build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"), 9300));
// 第一个参数:索引名;第二个参数:索引类型;第三个参数:索引ID(相同的id时修改数据,默认为随机字符串)
IndexResponse indexResponse = client.prepareIndex("twitter", "json", "1").setSource(json).get();
System.out.println(indexResponse);
// 不指定id会随机生成一个
//client.prepareIndex("twitter", "tweet").setSource(json);
client.close(); 2.索引数据批量插入(插入效率高)
// 批量插入数据,删除和修改也可以,不举例了
BulkRequestBuilder bulkRequest = client.prepareBulk();
IndexRequest request = client.prepareIndex("twitter", "tweet", "1").setSource(json).request();
IndexRequest request2 = client.prepareIndex("twitter", "tweet", "2").setSource(json2).request();
bulkRequest.add(request);
bulkRequest.add(request2);
bulkRequest.execute().actionGet(); 3.判断索引是否存在
IndicesExistsRequest inExistsRequest = new IndicesExistsRequest("twitter");
IndicesExistsResponse inExistsResponse = client.admin().indices().exists(inExistsRequest).actionGet();
System.out.println("索引twitter是否存在:"+inExistsResponse.isExists()); 4.删除索引
//删除索引twitter
client.admin().indices().prepareDelete("twitter").execute().actionGet();
//删除索引中的某个文档(一条数据)
client.prepareDelete("twitter", "tweet", "1"); 5.查询索引库
Client client = TransportClient.builder().build()
.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"), 9300)); // 第一个参数:要查找的内容 第二,三个参数:要查找的字段
QueryBuilder qb = QueryBuilders.multiMatchQuery("喧嚣", "content","message");
// twitter:索引名 tweet:索引类型
SearchResponse response = client.prepareSearch("twitter").setTypes("tweet").setQuery(qb)
//设置查询类型 SearchType.QUERY_AND_FETCH:全部获取
.setSearchType(SearchType.DFS_QUERY_AND_FETCH).execute().actionGet(); SearchHits hits = response.getHits();
if (hits.totalHits() > 0) {
for (SearchHit hit : hits) {
System.out.println("score:" + hit.getScore() + ":\t" + hit.getSource());// .get("title")
}
} else {
System.out.println("搜到0条结果");
}
client.close(); 6.刷新索引
//刷新所有
client.admin().indices().prepareRefresh().get();
//刷新某一个
client.admin().indices().prepareRefresh("twitter").get();
//刷新某个类型
client.admin().indices().prepareRefresh("twitter","tweet").get(); 7.更新索引数据
//更新索引(根据索引,类型,id)
UpdateRequest updateRequest = new UpdateRequest();
updateRequest.index("twitter");
updateRequest.type("tweet");
updateRequest.id("1");
updateRequest.doc(jsonBuilder().startObject().field("content", "如果我说爱我没有如果").endObject());
client.update(updateRequest).get();

UpdateRequest updateRequest = new UpdateRequest("twitter", "tweet", "1")
.doc(jsonBuilder().startObject().field("content", "如果我说爱我没有如果").endObject());
client.update(updateRequest).get(); 8.插入更新
//插入更新(如果不存在id为3的则插入content为IndexRequest的内容,如果存在则更新content为UpdateRequest的内容)
IndexRequest indexRequest = new IndexRequest("twitter", "tweet", "3")
.source(jsonBuilder().startObject()
.field("content", "每当我迷失在黑夜里")
.endObject());
UpdateRequest updateRequest2 = new UpdateRequest("twitter", "tweet", "3")
.doc(jsonBuilder().startObject()
.field("content", "请照亮我前行")
.endObject())
.upsert(indexRequest);
client.update(updateRequest2).get();
client.close();

最新文章

  1. Merge Sorted Array
  2. php-resque的设计和使用
  3. iPhone系列设备媒体查询:
  4. Unity多单位战斗寻路问题的一种解决办法
  5. Solr主从集群配置简要说明
  6. Android快捷键
  7. Area(Pick定理POJ1256)
  8. mysql的学习笔记(六)
  9. yum程序下载被占用
  10. LeetCode 171 Excel Sheet Column Number 解题报告
  11. WPF中在XAML中实现数据类型转换的两种方法
  12. TP5.0+小程序商城构建(1)
  13. Redhat 简单本地yum 配置
  14. 关于vue2.0获取后端数据
  15. Animation鱼眼效果
  16. [Node.js] Child Process with fork() to handle heavy calculation process
  17. 跨域在嵌入页面iframe中设置cookie
  18. 【转】CentOS下expect 安装
  19. Linux ssh服务
  20. linux安装php sphinx出错

热门文章

  1. .NET Core 常用第三方包
  2. Xamarin开发综述
  3. 南宁AI项目
  4. git基本命令总结
  5. 第一章 Django之学习Django所需知识(3)
  6. C++——数组形参退化为指针
  7. 台式机电脑u盘启动识别不到U盘设置
  8. PAT Basic 1089 狼人杀-简单版 (20 分)
  9. python自动华 (四)
  10. HDU 6134 Battlestation Operational | 2017 Multi-University Training Contest 8