Elasticsearch——query string

本文详细介绍了Elasticsearch中QueryString查询的基础语法,包括如何使用q=field:searchcontent进行精确查询,以及如何利用+和-符号进行必须包含或排除的条件设置。此外,还探讨了_all元数据的作用及在生产环境中的应用限制,以及QueryString查询时的分词机制,强调了查询字符串必须使用与索引建立时相同的analyzer进行分词。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. query string基础语法
1GET /test_index/test_type/_search?q=test_field:test
2GET /test_index/test_type/_search?q=+test_field:test 必须包含,其实跟上面一样
3GET /test_index/test_type/_search?q=-test_field:test 不包含
复制代码

一个是掌握q=field:search content的语法,还有一个是掌握+和-的含义

2. _all metadata

在搜索的时候,如果没有指定搜索的字段,就默认搜索 _all field, 其中包含了所有 field 的值。

es中的_all元数据,在建立索引的时候,我们插入一条document,它里面包含了多个field,此时,es会自动将多个field的值,全部用字符串的方式串联起来,变成一个长的字符串,作为_all field的值,同时建立索引。

例如:

1{
2  "name""jack",
3  "age"26,
4  "email""jack@sina.com",
5  "address""guangzhou"
6}
复制代码

"jack 26 jack@sina.com guangzhou",作为这一条document的_all field的值,同时进行分词后建立对应的倒排索引.

在生产环境下不使用。

3. query string 的分词
  1. query string必须以和index建立时相同的analyzer进行分词
  2. query string对exact value和full text的区别对待

转载于:https://juejin.im/post/5c6abebe51882562e87640d2

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)来了解更多关于使用Elasticsearch和Golang的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值