go对elasticsearch的增删改查
环境
elasticsearch 6.8 (6.x版本应该都没问题)
go客户端sdk: github.com/elastic/go-elasticsearch/v6
其实自己封装api也行,反正elasticsearch对外交互的协议是restful接口
注意点
发起的请求,如果成功了,一定要记得关闭返回Response的Body,否则会占用一个连接。
全局变量和函数
var c *elasticsearch.Client
func init() {
var err error
config := elasticsearch.Config{}
config.Addresses = []string{"http://127.0.0.1:9200"}
c, err = elasticsearch.NewClient(config)
checkError(err)
}
func checkError(err error) {
if err != nil {
fmt.Println(err)
os.Exit(1)
}
}
创建索引
func createIndex() {
body := map[string]interface{}{
"mappings": map[string]interface{}{
"test_type": map[string]interface{}{
"properties": map[string]interface{}{
"str": map[string]interface{}{
"type": "keyword", // 表示这个字段不分词
},
},
},
},
}
jsonBody, _ := json.Marshal(body)
req := esapi.IndicesCreateRequest{
Index: "test_index",
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"acknowledged":true,"shards_acknowledged":true,"index":"test_index"}
删除索引
func deleteIndex() {
req := esapi.IndicesDeleteRequest{
Index: []string{"test_index"},
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"acknowledged":true}
往索引插入数据
插入单条数据
func insertSingle() {
body := map[string]interface{}{
"num": 0,
"v": 0,
"str": "test",
}
jsonBody, _ := json.Marshal(body)
req := esapi.CreateRequest{ // 如果是esapi.IndexRequest则是插入/替换
Index: "test_index",
DocumentType: "test_type",
DocumentID: "test_1",
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[201 Created] {"_index":"test_index","_type":"test_type","_id":"test_1","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":0,"_primary_term":1}
批量插入(很明显,也可以批量做其他操作)
func insertBatch() {
var bodyBuf bytes.Buffer
for i := 2; i < 10; i++ {
createLine := map[string]interface{}{
"create": map[string]interface{}{
"_index": "test_index",
"_id": "test_" + strconv.Itoa(i),
"_type": "test_type",
},
}
jsonStr, _ := json.Marshal(createLine)
bodyBuf.Write(jsonStr)
bodyBuf.WriteByte('\n')
body := map[string]interface{}{
"num": i % 3,
"v": i,
"str": "test" + strconv.Itoa(i),
}
jsonStr, _ = json.Marshal(body)
bodyBuf.Write(jsonStr)
bodyBuf.WriteByte('\n')
}
req := esapi.BulkRequest{
Body: &bodyBuf,
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"took":31,"errors":false,"items":[{"create":{"_index":"test_index","_type":"test_type","_id":"test_2","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":0,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_3","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":1,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_4","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":2,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_5","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":0,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_6","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":1,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_7","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":1,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_8","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":2,"_primary_term":1,"status":201}},{"create":{"_index":"test_index","_type":"test_type","_id":"test_9","_version":1,"result":"created","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":3,"_primary_term":1,"status":201}}]}
查询
通过sql查询
func selectBySql() {
query := map[string]interface{}{
"query": "select count(*) as cnt, max(v) as value, num from test_index where num > 0 group by num",
}
jsonBody, _ := json.Marshal(query)
req := esapi.XPackSQLQueryRequest{
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"columns":[{"name":"cnt","type":"long"},{"name":"value","type":"long"},{"name":"num","type":"long"}],"rows":[[2,7.0,1],[3,8.0,2]],"cursor":"q47zAgFjAQp0ZXN0X2luZGV4igEBAQljb21wb3NpdGUHZ3JvdXBieQEDbWF4Ajg2AAD/AQF2AAAA/wAA/wEAAjc4AQNudW0AAAH/AADoBwEKAQI3OAIAAAAAAAAAAgACAQAAAAABAP////8PAAAAAAEFcmFuZ2U/gAAAAANudW0BAAAAAP8AAAAAAAAAAAAAAAABWgMAAgIAAAAAAAH/////DwMBawI3OAEBWgABbQI4NgV2YWx1ZQAAAVoBawI3OAABWgABBw=="}
通过Search Api查询
func selectBySearch() {
query := map[string]interface{}{
"query": map[string]interface{}{
"bool": map[string]interface{}{
"filter": map[string]interface{}{
"range": map[string]interface{}{
"num": map[string]interface{}{
"gt": 0,
},
},
},
},
},
"size": 0,
"aggs": map[string]interface{}{
"num": map[string]interface{}{
"terms": map[string]interface{}{
"field": "num",
//"size": 1,
},
"aggs": map[string]interface{}{
"max_v": map[string]interface{}{
"max": map[string]interface{}{
"field": "v",
},
},
},
},
},
}
jsonBody, _ := json.Marshal(query)
req := esapi.SearchRequest{
Index: []string{"test_index"},
DocumentType: []string{"test_type"},
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"took":10,"timed_out":false,"_shards":{"total":5,"successful":5,"skipped":0,"failed":0},"hits":{"total":5,"max_score":0.0,"hits":[]},"aggregations":{"num":{"doc_count_error_upper_bound":0,"sum_other_doc_count":0,"buckets":[{"key":2,"doc_count":3,"max_v":{"value":8.0}},{"key":1,"doc_count":2,"max_v":{"value":7.0}}]}}}
但是elasticsearch对聚合查询分页并不是很友好,基本上都是得自己手动分页。
局部更新(批量更新略)
根据id更新
func updateSingle() {
body := map[string]interface{}{
"doc": map[string]interface{}{
"v": 100,
},
}
jsonBody, _ := json.Marshal(body)
req := esapi.UpdateRequest{
Index: "test_index",
DocumentType: "test_type",
DocumentID: "test_1",
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"_index":"test_index","_type":"test_type","_id":"test_1","_version":2,"result":"updated","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":3,"_primary_term":1}
除了doc方式之外,还有script方式
根据条件更新
func updateByQuery() {
body := map[string]interface{}{
"script": map[string]interface{}{
"lang": "painless",
"source": `
ctx._source.v = params.value;
`,
"params": map[string]interface{}{
"value": 101,
},
},
"query": map[string]interface{}{
"match_all": map[string]interface{}{},
},
}
jsonBody, _ := json.Marshal(body)
req := esapi.UpdateByQueryRequest{
Index: []string{"test_index"},
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"took":109,"timed_out":false,"total":9,"updated":9,"deleted":0,"batches":1,"version_conflicts":0,"noops":0,"retries":{"bulk":0,"search":0},"throttled_millis":0,"requests_per_second":-1.0,"throttled_until_millis":0,"failures":[]}
删除
根据id删除
func deleteSingle() {
req := esapi.DeleteRequest{
Index: "test_index",
DocumentType: "test_type",
DocumentID: "test_1",
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"_index":"test_index","_type":"test_type","_id":"test_1","_version":6,"result":"deleted","_shards":{"total":2,"successful":1,"failed":0},"_seq_no":7,"_primary_term":1}
根据条件删除
func deleteByQuery() {
body := map[string]interface{}{
"query": map[string]interface{}{
"match_all": map[string]interface{}{},
},
}
jsonBody, _ := json.Marshal(body)
req := esapi.DeleteByQueryRequest{
Index: []string{"test_index"},
Body: bytes.NewReader(jsonBody),
}
res, err := req.Do(context.Background(), c)
checkError(err)
defer res.Body.Close()
fmt.Println(res.String())
}
[200 OK] {"took":17,"timed_out":false,"total":9,"deleted":9,"batches":1,"version_conflicts":0,"noops":0,"retries":{"bulk":0,"search":0},"throttled_millis":0,"requests_per_second":-1.0,"throttled_until_millis":0,"failures":[]}
go对elasticsearch的增删改查的更多相关文章
- 使用kibana操作elasticsearch实现增删改查
本篇博客,本人写的是方法,大家将对应的字段放入对应的位置就可以了 注:elasticsearch中,索引相当于MySQL中的数据库,类型相当于数据库中的表,即索引名就为数据库库名,类型就为表名 1.创 ...
- ElasticSearch入门-增删改查(java api)
1.增加Index PutMappingRequest mapping = Requests.putMappingRequest(indices).type(mappingType).source(g ...
- Curl实现ElasticSearch的增删改查
一.添加数据(laravel必须安装Curl扩展) $data = [ 'username'=>"张三", 'sex'=>"女", 'age'=&g ...
- elasticsearch增删改查crudp-----1
Elasticsearch一些增删改查的总结 环境Centos7+Es 5.x 简单介绍下ES的原理: 1,索引 --相当于传统关系型数据库的database或schema 2,类型 --相当于传 ...
- kibana的Dev Tool中如何对es进行增删改查
kinaba Dev Tool中对es(elasticSearch)进行增删改查 一.查询操作 查询语句基本语法 以下语句类似于mysql的: select * from xxx.yyy.topic ...
- Elasticsearch 单模式下API的增删改查操作
<pre name="code" class="html">Elasticsearch 单模式下API的增删改查操作 http://192.168. ...
- 【ES】ElasticSearch初体验之使用Java进行最基本的增删改查~
好久没写博文了, 最近项目中使用到了ElaticSearch相关的一些内容, 刚好自己也来做个总结. 现在自己也只能算得上入门, 总结下自己在工作中使用Java操作ES的一些小经验吧. 本文总共分为三 ...
- elasticsearch实例讲解增删改查
1.首先弄明白四个概念 elasticsearch 关系型数据库 index 数据库 type 表 document 行 field 字段 如果刚一开始理解比较困难,那你就在心中默念100遍,10遍也 ...
- Elasticsearch学习系列之单模式下API的增删改查操作
这里我们通过Elasticsearch的marvel插件实现单模式下API的增删改查操作 索引的初始化操作 创建索引之前可以对索引进行初始化操作,比如先指定shard数量以及replicas的数量 代 ...
随机推荐
- sqler 集成 terraform v0.12 生成资源部署文件
terraform v0.12 发布了,有好多新功能的添加,包括语法的增强,新函数的引入,更好的开发提示 只是当前对于一些老版本的provider 暂时还不兼容,但是大部分官方的provider 都是 ...
- nodejs之mysql查询
示例代码中的mysql版本 2.14.1 参考代码 /** * 测试mysql连接 */ var mysql = require('mysql'); var connection = mysql.cr ...
- 选择排序python实现
选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完.注意每次查找 ...
- gdb 调试core文件报错: in free () from /lib64/libc.so.6 找不到原因啊
运行程序死掉 找不到原因啊..gdb 跟踪与堆栈信息 贴出来了 麻烦大佬们看一下,给个回复,不胜感激!! Core was generated by `./scene_s0037 10037'.Pr ...
- 【AtCoder】 ARC 103
link C-//// 直接算会出现奇偶两组选了同一个数,注意处理一下就行 #include<bits/stdc++.h> #define ll long long #define dbg ...
- avalon数据已更新,视图未更新的bug修复
$computed: { pinlei() { var key = this.currentProduct.key || 'youpin'; console.log(key, "我是key& ...
- SpringCloud Feign通过FallbackFactory显示异常信息
SpringCloud Feign可以进行服务消费,而且内置了Hystrix,能够进行熔断. Feign可以通过fallback指定熔断回调的类.代码示例及讲解可见: https://www.cnbl ...
- maven依赖 dependency中scope=compile 和 provided区别
问题再现 上次这边朋友问我一个问题,就是他们在pom.xml中的dependency中,看到有一些是provided的情况,比如如下: <dependency> <groupId&g ...
- Java多个线程顺序打印数字
要求 启动N个线程, 这N个线程要不间断按顺序打印数字1-N. 将问题简化为3个线程无限循环打印1到3 方法一: 使用synchronized 三个线程无序竞争同步锁, 如果遇上的是自己的数字, 就打 ...
- 009 SpringBoot+Swagger的使用
一:概述 1.说明 Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务. 总体目标是使客户端和文件系统作为服务器以同样的速度来更新. 文件的方法 ...