当前位置: 首页 > article >正文

Go查询Elasticsearch

在 Go 中需要在 Elasticsearch 中执行带有过滤条件的查询时,你可以使用 github.com/olivere/elastic 库的过滤器(Filter)功能。以下是一个示例代码,展示了如何在 Go 中使用 Elasticsearch 进行带有过滤条件的分页查询:

package main

import (
	"context"
	"fmt"
	"log"

	"github.com/olivere/elastic/v7"
)

func main() {
	// 创建 Elasticsearch 客户端
	client, err := elastic.NewClient(elastic.SetURL("http://your-elasticsearch-host:9200"))
	if err != nil {
		// 处理错误
		log.Fatalf("Error creating the client: %s", err)
	}

	// 准备查询和过滤条件
	query := elastic.NewMatchAllQuery()
	filter := elastic.NewRangeQuery("age").Gte(18)

	// 设置分页参数
	pageSize := 10
	pageNumber := 1
	from := (pageNumber - 1) * pageSize

	// 执行查询
	searchResult, err := client.Search().
		Index("your-index").
		Query(query).
		PostFilter(filter). // 将过滤条件添加为 PostFilter
		From(from).
		Size(pageSize).
		Do(context.Background())
	if err != nil {
		// 处理错误
		log.Fatalf("Error executing the search: %s", err)
	}

	// 处理搜索结果
	fmt.Printf("Total hits: %d\n", searchResult.TotalHits())
	for _, hit := range searchResult.Hits.Hits {
		var data map[string]interface{}
		err := json.Unmarshal(hit.Source, &data)
		if err != nil {
			log.Printf("Error unmarshalling JSON: %s", err)
		}
		fmt.Printf("Document ID: %s, Data: %v\n", hit.Id, data)
	}
}

在这个示例中,我们添加了一个名为 filter 的过滤条件,并使用 PostFilter 方法将其添加到查询中。这样,我们就可以在查询中同时使用查询条件和过滤条件。这个示例中的过滤条件是一个范围查询,用来过滤出年龄大于等于 18 岁的文档。
更多查询可以用更多的方法:
例如,要匹配 “file” 字段为 “/var/audit.log” 的的数据
termQuery := elastic.NewTermQuery("file", "/var/paas/sys/log/kubernetes/audit/audit.log")

同样,请替换代码中的 http://your-elasticsearch-host:9200your-index 分别为你的 Elasticsearch 主机地址和索引名称。

希望这个示例能够帮助你使用 Go 语言向 Elasticsearch 发送带有过滤条件的分页请求。如果你有其他问题或需要进一步的帮助,请随时告诉我。


http://www.kler.cn/a/154448.html

相关文章:

  • 有序数组的平方(leetcode 977)
  • 某某科技笔试题
  • PCL 三维重建 耳切三角剖分算法
  • Scratch 014生日贺卡(上)
  • 《生成式 AI》课程 第3講 CODE TASK 任务3:自定义任务的机器人
  • day-83 最少翻转次数使二进制矩阵回文 II
  • 【brpc学习实践十一】session-local与thread-local应用与brpc抽象工厂模式实践
  • Mybatis 分页查询的三种实现
  • css取消移动端长按元素背景色
  • OCR原理解析
  • Redis面试常见问题
  • Python基础学习快速入门
  • ESP32-Web-Server 实战编程-通过网页控制设备多个 GPIO
  • SpringBoot拦截器、过滤器、自定义注解、监听器、全局异常-使用详解
  • Vue3中定义变量是选择ref还是reactive?
  • 使用KubeSphere练习故障注入
  • SELinux refpolicy详解(4)
  • Layer Normalization是什么
  • Oauth2.0 学习
  • 180天Java从小白到就业-Day03-03Java位运算符、赋值运算符、数据交换的三种方式
  • P1 什么是链表 C语言简单易懂
  • Sql Server数据库跨机器完整恢复(源文件恢复)
  • QPrinter 是 Qt 框架中的一个类,用于与打印机进行交互,并提供打印功能
  • Linux 进程(三)
  • 每日一练:冒泡排序
  • 7、Jenkins+Nexus3+Docker+K8s实现CICD