Go 客户端中的 ES|QL

编辑

此页面帮助您理解和使用 Go 客户端中的 ES|QL

在 Go 客户端中有两种使用 ES|QL 的方法:

  • 直接使用 Elasticsearch ES|QL API:这是最灵活的方法,但也是最复杂的方法,因为您必须以原始形式处理结果。您可以选择精确的结果格式,例如 JSON、CSV 或文本。
  • 使用 ES|QL 映射助手:这些映射器负责将原始响应解析为应用程序可以立即使用的内容。助手可用于对象映射和迭代对象。

如何使用 ES|QL API

编辑

ES|QL 查询 API 允许您指定结果的返回方式。您可以选择诸如 CSV、文本或 JSON 等 响应格式,然后使用列分隔符和区域设置等参数对其进行微调。

以下示例获取 CSV 格式的 ES|QL 结果并解析它们

queryAuthor := `from library
    | where author == "Isaac Asimov"
    | sort release_date desc
    | limit 10`

response, err := client.Esql.Query().
    Query(queryAuthor).
    Format("csv").
    Do(context.Background())
if err != nil {
    log.Fatal(err)
}

reader := csv.NewReader(bytes.NewReader(response))
rows, err := reader.ReadAll()
for _, row := range rows {
    fmt.Println(row)
}

使用 ES|QL 结果

编辑

前面的示例表明,尽管原始 ES|QL API 提供了最大的灵活性,但要使用结果数据还需要额外的工作。

为了简化操作,请尝试使用以下两种主要的 ES|QL 结果表示形式(每种都有自己的映射助手):

  • 对象,其中结果中的每一行都映射到应用程序域中的一个对象。这类似于 ORM(对象关系映射器)通常的做法。
package main

import (
	"context"
	"fmt"
	"log"

	"github.com/elastic/go-elasticsearch/v8"
	"github.com/elastic/go-elasticsearch/v8/typedapi/esql/query"
)

type Book struct {
	Name        string `json:"name"`
	Author      string `json:"author"`
	ReleaseDate string `json:"release_date"`
	PageCount   int    `json:"page_count"`
}

func main() {
	client, err := elasticsearch.NewTypedClient(elasticsearch.Config{Addresses: []string{"ELASTICSEARCH_URL"}})
	if err != nil {
		log.Fatal(err)
	}

	queryAuthor := `from library
        | where author == "Isaac Asimov"
        | sort release_date desc
        | limit 10`

	qry := client.Esql.Query().Query(queryAuthor)
	books, err := query.Helper[Book](context.Background(), qry)
	if err != nil {
		log.Fatal(err)
	}

	for _, book := range books {
		fmt.Println(book)
	}
}
  • 迭代对象,其中结果中的每一行一次映射到应用程序域中的一个对象。
queryAuthor := `from library
    | where author == "Isaac Asimov"
    | sort release_date desc
    | limit 10`

qry := client.Esql.Query().Query(queryAuthor)
books, err := query.NewIteratorHelper[Book](context.Background(), qry)
if err != nil {
    log.Fatal(err)
}

for books.More() {
    book, err := books.Next()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println(book)
}