0

0

聊聊Go语言查询Elasticsearch关知识

PHPz

PHPz

发布时间:2023-04-10 14:18:45

|

1307人浏览过

|

来源于php中文网

原创

elasticsearch 是一个开源的分布式搜索引擎,广泛应用于各种搜索和数据分析场景。与此同时,go语言作为一种高效而便捷的编程语言,也受到越来越多的开发者的喜爱和使用。针对 elasticsearch 的高性能查询和数据分析功能,go 也提供了一些方便的查询库和框架。本文将对 go 语言查询 elasticsearch 的相关知识进行详细介绍,帮助大家更好地实现 elasticsearch 查询。

一、Go语言库介绍

Go 语言中已有了一些成熟的 Elasticsearch 查询库,下面根据各自的特点简要介绍它们。

  1. go-elasticsearch

go-elasticsearch 是 Elasticsearch 官方推出的一个由 Go 语言实现的 Elasticsearch 客户端,同时也包含 Elasticsearch 的查询和分析功能。尤其在 Elasticsearch 7.x 版本之后,go-elasticsearch 已经成为了 Elasticsearch 官方推荐的 Go 语言库。go-elasticsearch 可以运行在多个操作系统平台上,并且已经支持了 Elasticsearch 6.x 以及 7.x 版本。它的具体使用方式可以参考官方文档。

  1. go-es

go-es 是一款由小米公司开源的 Elasticsearch Go 客户端,由于其简便易用、功能全面,已经成为国内大型互联网企业中得到广泛应用的 Elasticsearch 客户端库之一。go-es 库中的各种查询 API 的参数设计简单明了,并且语法与 Elasticsearch 的查询语法十分接近,因此可以直接使用 Elasticsearch 查询 DSL 进行查询。关于该库的详细使用方式,可以参考其 Github 仓库。

立即学习go语言免费学习笔记(深入)”;

  1. kingim/goes

goes 是一种简便易用的 Elasticsearch Go 客户端库。它极大地减少了 Elasticsearch 基础操作的学习成本,并支持接口和对象两种使用方式。除了查询和分析功能,goes 还提供了一个简单的地理坐标计算库,支持计算两个经纬度之间的距离和角度值。关于 kingim/goes 的详细使用方式,可以参考其 Github 仓库。

  1. olivere/elastic

olivere/elastic 是 Elasticsearch 的 Go 客户端库。类似于 go-elasticsearch 和 go-es,它们都为 Elasticsearch 提供了非常方便的查询 API。但是 olivere/elastic 更加注重查询结果的序列化和反序列化,支持多种输出格式(如Json、Xml等)的封装、筛选,适用于前后端结果交互等场景。您可以查看 olivere/elastic 的 Github 仓库获取更多使用细节。

二、查询 Elasticsearch

StickerBaker
StickerBaker

免费开源的AI贴纸头像生成工具

下载

在 Go 语言中,通过 Elasticsearch Go 客户端库,可以非常方便地进行 Elasticsearch 相关的查询、搜索和分析操作。从接口调用上来看,各个库的使用方法有些差异,但是基本的查询功能、语法和逻辑大同小异。下面我们举几个例子,介绍在 Go 中如何查询 Elasticsearch。

  1. 查询所有文档

es 官方文档推荐使用以下方式:

    Package main
    import (
        "context"
        "fmt"

        "github.com/elastic/go-elasticsearch/v7"
        "github.com/elastic/go-elasticsearch/v7/esapi"
        "github.com/elastic/go-elasticsearch/v7/esutil"
    )

    func main() {
        es, _ := elasticsearch.NewDefaultClient()
        req := esapi.SearchRequest{
            Body:     esutil.NewJSONReader(map[string]interface{}{"query": map[string]interface{}{"match_all": map[string]interface{}{}}}),
            Index:    []string{"my-index-000001"},
            TrackTotalHits: true,
        }
        res, err := req.Do(context.Background(), es)
        fmt.Println(res, err)
    }
  1. 查询包含某个词的文档

     q := elastic.NewTermQuery("content", "hello")
     searchResult, err := client.Search().
         Index("twitter").
         Query(q).
         Do(ctx)
     if err != nil {
         log.Fatalln(err)
     }
  2. 查询一定范围内的文档

     terms := []string{"world", "how", "are", "you"}
     q1 := elastic.NewTermsQuery("content", terms...)
     q2 := elastic.NewRangeQuery("publish_time").Gte("2021-01-01").Lte("2021-02-01")
     query := elastic.NewBoolQuery().Must(q1).Filter(q2)
     searchResult, err := client.Search().
         Index("twitter").
         Query(query).
         From(0).Size(10).
         Do(ctx)
     if err != nil {
         log.Fatalln(err)
     }
  3. 使用聚合函数实现分类统计

     agg := elastic.NewTermsAggregation().Field("category").Size(10000)
     query := elastic.NewMatchAllQuery()
     searchResult, err := client.Search().Index("goods").Size(0).Query(query).Aggregation("by_category", agg).Do(ctx)
     if err != nil {
         log.Fatalln(err)
     }
     bucketDateHists := searchResult.Aggregations.Terms("by_category")
     for _, bucket := range bucketDateHists.Buckets {
         fmt.Printf("%v: %d\n", bucket.Key, int(bucket.DocCount))
     }

三、总结

通过以上介绍,我们可以看到,Go 语言提供的 Elasticsearch 查询库非常丰富,并且操作起来也非常简单、高效。无论是在数据搜索还是数据分析,Go 语言都可以胜任其中的重要角色。当然,如果您想要更加深入地了解 Elasticsearch 或 Go 语言的相关知识,建议多阅读官方文档和源码,加深自己的理解和认识。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

226

2023.10.07

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

402

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1848

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2080

2024.08.01

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号