go操作es7的常用增删改查操作

go操作es7的常用增删改查操作

说明: 为了更好的操作,该文件放置一个文件. 有需要的伙伴可以进行提取封装
文件下载地址: https://github.com/yunziyuan/cntech-go

1.初始化连接es

使用时,修改es的地址

  var ctx = context.Background()
  var esUrl = "http://127.0.0.1:7010"
  var EsClient *elastic.Client

  // 初始化es连接
  func InitEs() {
      // 连接es客户端
      client, err := elastic.NewClient(
          elastic.SetURL(esUrl),
      )
      if err != nil {
          log.Fatal("es 连接失败:", err)
      }
      // ping通服务端,并获得服务端的es版本,本实例的es版本为version 7.6.1
      info, code, err := client.Ping(esUrl).Do(ctx)
      if err != nil {
          // Handle error
          panic(err)
      }
      fmt.Println("Elasticsearch returned with code>: %d and version %s\\n", code, info.Version.Number)

      EsClient = client
      fmt.Println("es连接成功")
  }

2.新增索引及数据结构

数据索引是为了为es指定字段类型

  // 定义数据结构体
  type data struct {
    Id   string \`json:"id"\`
    Icon string \`json:"icon"\`
    Name string \`json:"name"\`
    Age  int    \`json:"age"\`
  }

  // 定义一些变量,mapping为定制的index字段类型
  const mapping = \`
  {
    "settings":{
        "number_of_shards": 1,
        "number_of_replicas": 0
    },
    "mappings":{
        "properties":{
            "name":{
                "type":"keyword"
            },
            "icon":{
                "type":"text"
            },
            "age":{
                "type":"long"
            },
            "id":{
                "type":"text"
            }
        }
    }
  }\`

3.添加索引方法

新增数据时,应先判断是否存在索引

  // 添加文档
  func Addindex(table string) (bool, error) {
    // 创建index前,先查看es引擎中是否存在自己想要创建的索引index
    exists, err := EsClient.IndexExists(table).Do(ctx)
    if err != nil {
        fmt.Println("存在索引:", err)
        return true, nil
    }
    if !exists {
        // 如果不存在,就创建
        createIndex, err := EsClient.CreateIndex(table).BodyString(mapping).Do(ctx)
        if err != nil {
            return false, err
        }
        if !createIndex.Acknowledged {
            return false, err
        }
    }
    return true, nil
  }

2.增加方法

说明: 增加数据时, 我们会先判断是否存在索引

(1). 新增一条
// 添加数据
  func Add(table string, data interface{}) (bool, error) {
    // 添加索引
    _, err := Addindex(table)
    if err != nil {
        log.Fatal("创建索引失败", err)
    }
    // 添加文档
    res, err := EsClient.Index().
        Index(table).
        BodyJson(data).
        Do(ctx)
    if err != nil {
        return false, err
    }
    fmt.Println("添加数据成功:", res)
    return true, nil
  }

使用方法:
data := data{
    Id:   "1",
    Icon: "头像",
    Name: "名称",
    Age:  10,
}
res ,err := Add("test", data)

(2). 批量新增
  func BulkAdd(table string, d []data) (bool, error) {
    // 添加索引
    _, err := Addindex("test")
    if err != nil {
        log.Fatal("创建索引失败", err)
    }
    bulkReq := EsClient.Bulk()
    for _, v := range d {
        req := elastic.NewBulkIndexRequest().
            Index(table).
            Doc(v)
        bulkReq = bulkReq.Add(req)
    }
    res, err := bulkReq.Do(ctx)
    if err != nil {
        return false, err
    }
    fmt.Println("添加数据成功:", res)
    return true, nil
  }

使用方法:
var d []interface{}
for i := 0;i < 100; i++ {
    iStr := strconv.Itoa(i)
    v := data{
        Id: iStr,
        Icon: "icon " + iStr,
        Name: "name " + iStr,
        Age: i,
    }
    d = append(d, v)
}
res ,err := BulkAdd("test", d)

3.查询方法

sort 字段不能为text类型字段

  func Query(table string, field string, filter elastic.Query, sort string, page int, limit int) (*elastic.SearchResult, error) {
    // 分页数据处理
    isAsc := true
    if sort != "" {
        sortSlice := strings.Split(sort, " ")
        sort = sortSlice[0]
        if sortSlice[1] == "desc" {
            isAsc = false
        }
    }
    // 查询位置处理
    if page <= 1 {
        page = 1
    }

    fsc := elastic.NewFetchSourceContext(true)
    // 返回字段处理
    if field != "" {
        fieldSlice := strings.Split(field, ",")
        if len(fieldSlice) > 0 {
            for _, v := range fieldSlice {
                fsc.Include(v)
            }
        }
    }

    // 开始查询位置
    fromStart := (page - 1) * limit
    res, err := EsClient.Search().
        Index(table).
        FetchSourceContext(fsc).
        Query(filter).
        Sort(sort, isAsc).
        From(fromStart).
        Size(limit).
        Pretty(true).
        Do(ctx)
    if err != nil {
        return nil, err
    }
    return res, nil
  }

使用方法:
  // 精准查询
  //filter := elastic.NewTermQuery("name", "李白")

  // 分词匹配查询
  // match_all 查询所有
  filter := elastic.NewMatchAllQuery()
  // match 单个字符匹配
  // filter := elastic.NewMatchQuery("name", "渡汉江")
  // multi_match 多个字段进行匹配查询
  //filter := elastic.NewMultiMatchQuery("白日", "name", "icon")
  // match_phrase 短语匹配
  //filter := elastic.NewMatchPhraseQuery("icon", "途穷反遭俗眼白")

  // fuzzy模糊查询 fuzziness是可以允许纠正错误拼写的个数
  //filter := elastic.NewFuzzyQuery("icon", "夜").Fuzziness(1)

  // wildcard 通配符查询
  //filter := elastic.NewWildcardQuery("name", "静夜*")

  table := "test"
  sort := "age asc"
  page := 0
  limit := 10
  field := "name,icon,age"
  res, err := Query(table, field, filter, sort, page, limit)
  strD, _ := json.Marshal(res)
  fmt.Println(string(strD), err)

4.修改方法

  func UpWhere(table string, filter elastic.Query, data map[string]interface{}) (bool, error) {
    // 修改数据组装
    if len(data) < 0 {
        return false, errors.New("修改参数不正确")
    }
    scriptStr := ""
    for k := range data {
        scriptStr += "ctx._source." + k + " = params." + k + ";"
    }
    script := elastic.NewScript(scriptStr).Params(data)
    res, err := EsClient.UpdateByQuery(table).
        Query(filter).
        Script(script).
        Do(ctx)
    if err != nil {
        return false, err
    }
    fmt.Println("添加数据成功:", res)
    return true, nil
  }

使用方法:
  table := "test"
  filter := elastic.NewTermQuery("name", "name 0")
  data := make(map[string]interface{})
  data["icon"] = "world10"
  data["age"] = 10
  res, err := UpWhere(table, filter, data)

5.删除方法

  func Del(table string, filter elastic.Query) (bool, error) {
    res, err := EsClient.DeleteByQuery().
        Query(filter).
        Index(table).
        Do(ctx)
    if err != nil {
        return false, err
    }
    fmt.Println("删除信息:", res)
    return true, nil
  }

使用方法:
filter := elastic.NewTermQuery("name", "name 1")
res, err := Del("test", filter)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容