【Elasticsearch】Golang使用BoolQuery多条件查询

es的条件查询每次默认返回10条数据

boolQuery := elastic.NewBoolQuery()
	//boolQuery.Must(elastic.NewMatchQuery("user", "test1"))
	searchResult, err := esClient.Search().
		Index(index).
		Query(boolQuery).
		Size(20).
		From(0).
		Pretty(true).
		Do(context.Background())

Size(20).
From(0).

加上两个属性就可以变成20了

 

或者直接用kibana在该索引上执行

 

curl -XPUT http://localhost:9200/test_index/_settings -d '{ "index" : { "max_result_window" : 10000}}'

 

BoolQuery :添加条件进行查询

1、must 必须有的条件,每次查询一个数据

boolQuery := elastic.NewBoolQuery()

boolQuery.Must(elastic.NewMatchQuery("user", "张三"))

searchResult, err := esClient.Search().
		Index(index).
		Query(boolQuery).
		Size(10000).
		From(0).
		Pretty(true).
		Do(context.Background())

 此时查询的就是user为张三的数据,size为10000,默认不能大于10000,这个数值可以改,自行百度

2、should 可以有的条件,查询多个数据


boolQuery := elastic.NewBoolQuery()

boolQuery.Should(elastic.NewMatchQuery("user", "张三"))
boolQuery.Should(elastic.NewMatchQuery("user", "李四"))
boolQuery.Should(elastic.NewMatchQuery("user", "王五"))

searchResult, err := esClient.Search().
		Index(index).
		Query(boolQuery).
		Size(10000).
		From(0).
		Pretty(true).
		Do(context.Background())

此时查询的就是user为张三、李四、王五的数据

 

结果的遍历:

var user User
for _, item := range esResult.Each(reflect.TypeOf(user)) {
	if u, ok := item.(User); ok {
		//dosomething...
	}
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Elasticsearch是一个开源的分布式搜索和分析引擎,它提供了强大的全文搜索、结构化查询、分析能力和实时数据分析等功能。而Golang是一种编程语言,也被称为Go语言,它具有高效、简洁、并发安全等特点。 在Golang使用Elasticsearch可以通过第三方库进行操作,最常用的是官方提供的Elasticsearch客户端库——"github.com/elastic/go-elasticsearch"。这个库提供了与Elasticsearch进行交互的API,可以进行索引、搜索、聚合等操作。 使用go-elasticsearch库,你可以通过以下步骤来使用Elasticsearch: 1. 安装go-elasticsearch库:在终端中执行命令`go get github.com/elastic/go-elasticsearch/v8`来安装该库。 2. 导入库:在你的Go代码中导入"go.elastic.co/elasticsearch/v8"。 3. 创建Elasticsearch客户端:使用库提供的`elasticsearch.NewClient()`函数创建一个Elasticsearch客户端实例。 4. 执行操作:通过客户端实例调用相应的API方法来执行索引、搜索、聚合等操作。 以下是一个简单的示例代码,展示了如何使用go-elasticsearch库进行基本的索引和搜索操作: ```go package main import ( "context" "fmt" "log" "github.com/elastic/go-elasticsearch/v8" ) func main() { // 创建Elasticsearch客户端 cfg := elasticsearch.Config{ Addresses: []string{"http://localhost:9200"}, } es, err := elasticsearch.NewClient(cfg) if err != nil { log.Fatalf("Error creating the client: %s", err) } // 索引文档 doc := `{"title" : "Elasticsearch Golang Example"}` res, err := es.Index("my-index", strings.NewReader(doc)) if err != nil { log.Fatalf("Error indexing document: %s", err) } defer res.Body.Close() // 搜索文档 var buf bytes.Buffer query := map[string]interface{}{ "query": map[string]interface{}{ "match": map[string]interface{}{ "title": "example", }, }, } if err := json.NewEncoder(&buf).Encode(query); err != nil { log.Fatalf("Error encoding query: %s", err) } res, err = es.Search( es.Search.WithContext(context.Background()), es.Search.WithIndex("my-index"), es.Search.WithBody(&buf), es.Search.WithTrackTotalHits(true), es.Search.WithPretty(), ) if err != nil { log.Fatalf("Error searching for documents: %s", err) } defer res.Body.Close() // 处理搜索结果 var r map[string]interface{} if err := json.NewDecoder(res.Body).Decode(&r); err != nil { log.Fatalf("Error parsing the response body: %s", err) } fmt.Println(r) } ``` 这只是一个简单的示例,你可以根据自己的需求进行更复杂的操作。你可以参考go-elasticsearch库的文档(https://pkg.go.dev/github.com/elastic/go-elasticsearch/v8)来了解更多关于使用ElasticsearchGolang的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值