租用问题

质量为本、客户为根、勇于拼搏、务实创新

< 返回租用问题列表

Go操作ES-4(query查询),es查询原理

发布时间:2023-09-21 07:43:26

Go操作ES⑷(query查询)

在Go中操作Elasticsearch进行查询,需要使用Elasticsearch的官方Go客户端库。以下是一个简单的示例,演示怎样使用Go发送查询要求到Elasticsearch并获得结果:
```go
package main
import (
"context"
"fmt"
"log"
"strings"
"github.com/olivere/elastic"
)
func main() {
// 创建一个Elasticsearch客户端连接
client, err := elastic.NewClient(elastic.SetURL("http://localhost:9200"))
if err != nil {
log.Fatal(err)
}
// 构建查询条件
query := elastic.NewBoolQuery().
Must(elastic.NewMatchQuery("title", "go")).
Filter(elastic.NewRangeQuery("year").Gte(2010))
// 履行查询要求
searchResult, err := client.Search().
Index("books").
Query(query).
Do(context.Background())
if err != nil {
log.Fatal(err)
}
// 遍历查询结果
for _, hit := range searchResult.Hits.Hits {
fmt.Printf("ID: %s, Score: %f ", hit.Id, hit.Score)
}
// 输出查询结果的总数
fmt.Printf("Total hits: %d ", searchResult.Hits.TotalHits.Value)
}
```
在这个示例中,我们首先创建一个Elasticsearch客户端连接,并指定Elasticsearch的URL。然后,我们构建一个查询条件,使用`elastic.NewBoolQuery()`创建一个布尔查询对象,并使用`Must()`和`Filter()`方法添加查询条件。在这个示例中,我们使用`MatchQuery`查询标题中包括"go"的文档,并使用`RangeQuery`查询年份大于等于2010的文档。
接下来,我们使用`client.Search()`方法履行查询要求,并指定索引名称为"books"。然后,使用`Do()`方法发送要求并获得查询结果。
最后,我们遍历查询结果,并打印每一个结果的ID和得分。同时,我们还打印出查询结果的总数。
请注意,这只是一个简单的示例,实际使用中可能需要根据具体需求进行更复杂的查询。你可以根据Elasticsearch的查询DSL文档,使用区分的查询构造器来构建更复杂的查询条件。