分页多条件查询 ES
func TestESQueryDemo() {
// ES SDK 教程:https://www.yisu.com/zixun/694102.html
query := elastic.NewBoolQuery().
Must(elastic.NewMatchQuery("lastname", "smith")).
Filter(elastic.NewTermQuery("age", "20")).
Filter(elastic.NewRangeQuery("modify_time").Format("yyyy-MM-dd").Gte("2021-07-22").Lt("2021-07-23"))
ctx := context.Background()
index := "info"
result, err := client.Search(index).Query(query).Size(20).From(0).Do(ctx)
if err != nil {
logs.Error("err=%v", err)
}
for page, hit := range result.Hits.Hits {
//var t Employee
//err := json.Unmarshal(*hit.Source, &t) //另一种取出的方法
//if err != nil {
// fmt.Println("failed")
//}
//fmt.Printf("employee name %s:%s\n", t.FirstName, t.LastName)
logs.Info("page=%v, hit=%v", page, hit)
}
logs.Info("result=%v, err=%v", jsons.ToJSON(*result.Hits), err)
}
其他 api 使用参考:go语言操作es的方法