golang es操作

一、启动es

1、启动es
bin目录下找到elasticsearch.bat,启动
访问 http://127.0.0.1:9200/ ,启动成功
在这里插入图片描述
2、启动es head
输入npm run start
访问 http://localhost:9100 启动成功
在这里插入图片描述
3、启动kibana
bin目录下找到kibana.bat,启动
访问 http://localhost:5601
在这里插入图片描述

二、ES使用

基本概念

1、索引(indices)、type、documents、fields
分别对应数据库 数据库、表(table)、行(row)、字段(columns)

{index}:索引,根据需要自己设定,下面例子的索引为:customer
{type}:类型,根据需要自己设定,下面例子的索引为:external
{id}:文档id,根据需要自己设定

2、keywords和text

  • text取代了string,当一个字段是要被全文搜索的,比如Email内容、产品描述,应该使用text类型。设置text类型以后,字段内容会被分析,在生成倒排索引以前,字符串会被分析器分成一个一个词项。text类型的字段不用于排序,很少用于聚合(termsAggregation除外)
  • keyword类型适用于索引结构化的字段,比如email地址、主机名、状态码和标签。如果字段需要进行过滤(比如查找已发布博客中status属性为published的文章)、排序、聚合。keyword类型的字段只能通过精确值搜索到

索引

settings : 索引的设置
mappings : 映射
kibana添加索引
在这里插入图片描述

创建索引

PUT /student_001
{
  "mappings": {
    "dynamic": "true",
    "properties": {
      "birthday": {
        "type": "date",
        "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"
      },
      "introduce": {
        "type": "text"
      },
      "name": {
        "type": "keyword"
      },
      "sex": {
        "type": "keyword"
      },
      "stu_id": {
        "type": "long"
      }
    }
  }
}

查看索引当前的mapping

GET student_001/_mapping

ES索引的mapping在设置之后是不可以更改字段类型的,但是可以给字段添加新的属性
添加新属性语句

PUT student_001/_mapping
{
"properties":{
  "tags" : {
    "type" : "keyword"
  }
  }
}

删除索引 DELETE /索引名
查看是否删除成功:HEAD /索引名
示例

HEAD student_001
DELETE student_001

查看所有索引

GET _all

插入数据

  • 如果使用 POST+update 方式,则只会更改对应的字段,其它字段不变,是局部更新;
  • 否则使用put或post方式将导致其它数据变化,数据全局更新。

使用 PUT /index/type/id 添加数据,修改数据

PUT student_001/_doc/1
{
  "name":"abc1",
  "birthday":"2023-07-01 00:00:00",
  "tags" :"{\"jump_type\":3,\"jump_url\":\"https://www.baidu.com/index.htm\"}"
}

局部更新

POST /test_index/my_type/1/_update 
{ 
  "doc":{ 
    "name":" test" 
  } 
}

查询数据

  • match查询是一个标准查询,不管你需要全文本查询还是精确查询基本上都要用到它
  • term查询是直接通过倒排索引指定的词条进行精确查找

关于分词:

  • term 直接查询精确
  • match 会使用分词器解析(先分析文档,在通过分析的文档进行查询)

布尔查询 (bool query)

  • must 与关系 相当于and
  • should 或关系 相当于or
  • must not 非关系 相当于not
  • filter 过滤条件
  • range 条件筛选范围
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Elasticsearch是一个开源的分布式搜索和分析引擎,它提供了强大的全文搜索、结构化查询、分析能力和实时数据分析等功能。而Golang是一种编程语言,也被称为Go语言,它具有高效、简洁、并发安全等特点。 在Golang中使用Elasticsearch可以通过第三方库进行操作,最常用的是官方提供的Elasticsearch客户端库——"github.com/elastic/go-elasticsearch"。这个库提供了与Elasticsearch进行交互的API,可以进行索引、搜索、聚合等操作。 使用go-elasticsearch库,你可以通过以下步骤来使用Elasticsearch: 1. 安装go-elasticsearch库:在终端中执行命令`go get github.com/elastic/go-elasticsearch/v8`来安装该库。 2. 导入库:在你的Go代码中导入"go.elastic.co/elasticsearch/v8"。 3. 创建Elasticsearch客户端:使用库提供的`elasticsearch.NewClient()`函数创建一个Elasticsearch客户端实例。 4. 执行操作:通过客户端实例调用相应的API方法来执行索引、搜索、聚合等操作。 以下是一个简单的示例代码,展示了如何使用go-elasticsearch库进行基本的索引和搜索操作: ```go package main import ( "context" "fmt" "log" "github.com/elastic/go-elasticsearch/v8" ) func main() { // 创建Elasticsearch客户端 cfg := elasticsearch.Config{ Addresses: []string{"http://localhost:9200"}, } es, err := elasticsearch.NewClient(cfg) if err != nil { log.Fatalf("Error creating the client: %s", err) } // 索引文档 doc := `{"title" : "Elasticsearch Golang Example"}` res, err := es.Index("my-index", strings.NewReader(doc)) if err != nil { log.Fatalf("Error indexing document: %s", err) } defer res.Body.Close() // 搜索文档 var buf bytes.Buffer query := map[string]interface{}{ "query": map[string]interface{}{ "match": map[string]interface{}{ "title": "example", }, }, } if err := json.NewEncoder(&buf).Encode(query); err != nil { log.Fatalf("Error encoding query: %s", err) } res, err = es.Search( es.Search.WithContext(context.Background()), es.Search.WithIndex("my-index"), es.Search.WithBody(&buf), es.Search.WithTrackTotalHits(true), es.Search.WithPretty(), ) if err != nil { log.Fatalf("Error searching for documents: %s", err) } defer res.Body.Close() // 处理搜索结果 var r map[string]interface{} if err := json.NewDecoder(res.Body).Decode(&r); err != nil { log.Fatalf("Error parsing the response body: %s", err) } fmt.Println(r) } ``` 这只是一个简单的示例,你可以根据自己的需求进行更复杂的操作。你可以参考go-elasticsearch库的文档(https://pkg.go.dev/github.com/elastic/go-elasticsearch/v8)来了解更多关于使用ElasticsearchGolang的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值