Go 客户端中的 ES|QL
编辑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) }