Elasticsearch 谜之null values

很多时候,我们需要面临null值的烦扰,查询es时传入null值是要查询出null的数据还是不查这个field呢,稍有不慎就会引发新的bug,这的确是个问题!

null_value 意味着无法索引或搜索空值。当字段设置为 null , [] ,和 [null] (这些null的表示形式都是等价的),它被视为该字段没有值。

null_value 意味着它将不会被表示为一个反向索引数据结构,它们根本不存在于反向索引中,故搜索也就无任何意义了。

难道就搜索没有办法了吗?

es为我们提供了missing查询,代表缺少字段或null值,但在6.x版本已经移除。取而代之的是exists查询,它的语义相当于SQL 中的 column is not null(有值)。它们都属于聚合操作。

显然,这个世界并不简单,数据常常缺少字段,或者包含显式的空或空数组。为了处理这些情况,es 给我们推荐了一些办法可以处理空值或缺少的值。

幸运的是,es 可以设置一个选项,用我们选择的占位符值替换显式的空值(当为字符串、数字、布尔值或日期字段指定映射时设置),当insert/update数据遇到空值时,将使用该值,这个显式的空值会对其进行索引,以便于搜索。

选择合适的空值时,请确保:

  • 它与字段的类型匹配。在日期类型的字段中不能使用字符串空值
  • 它不同于字段可能包含的正常值,以避免将实值与空值混淆

PUT my_index
{
  "mappings": {
    "_doc": {
      "properties": {
        "status_code": {
          "type":       "keyword",
          "null_value": "NULL" 
        }
      }
    }
  }
}

PUT my_index/_doc/1
{
  "status_code": null
}

PUT my_index/_doc/2
{
  "status_code": [] 
}

GET my_index/_search
{
  "query": {
    "term": {
      "status_code": "NULL" 
    }
  }
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Helm部署Elasticsearch的步骤如下: 1. 首先,需要添加Elasticsearch的Chart仓库和更新仓库信息: ``` helm repo add elastic https://helm.elastic.co helm repo update ``` 2. 接下来,可以使用以下命令安装Elasticsearch Master节点: ``` helm install elasticsearch-master -f es-master-values.yaml --version 7.7.1 elastic/elasticsearch ``` 使用`-f`参数指定部署配置文件,`--version`参数指定使用的Helm Chart版本。 3. 然后,使用以下命令安装Elasticsearch Data节点: ``` helm install elasticsearch-data -f es-data-values.yaml --version 7.7.1 elastic/elasticsearch ``` 4. 最后,使用以下命令安装Elasticsearch Client节点: ``` helm install elasticsearch-client -f es-client-values.yaml --version 7.7.1 elastic/elasticsearch ``` 请注意,以上命令是基于默认命名空间安装的。如果要指定命名空间,请在命令中使用`-n`参数。 引用每个节点的作用如下: - `elasticsearch-master`:ES主节点Pod,负责集群的管理和协调。 - `elasticsearch-data`:ES数据节点Pod,负责存储和处理数据。 - `elasticsearch-client`:ES客户端节点Pod,用于与ES集群进行交互。 另外,还可以通过访问Kibana来浏览Elasticsearch数据。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Helm部署ElasticSearch & Kibana 7 集群](https://blog.csdn.net/a772304419/article/details/113665348)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [Kubernetes Helm3 部署 ElasticSearch集群 & Kibana 7 & Filebeat 收集展示日志](https://blog.csdn.net/weixin_38299857/article/details/114665712)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值