分页多条件查询 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的方法