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

es之null_value

官方文档

https://www.elastic.co/guide/en/elasticsearch/reference/8.8/null-value.html

什么是null值

在es中, null, [], [null] 这三个值会被当成null值(空值)

null值不能做搜索参数

get /dev-member/_search
{
  "query":{
    "term": {
      "employee_id": null
    }
  }
}

会报错:

{
  "error": {
    "root_cause": [
      {
        "type": "illegal_argument_exception",
        "reason": "field name is null or empty"
      }
    ],
    "type": "illegal_argument_exception",
    "reason": "field name is null or empty"
  },
  "status": 400
}

原因是es不会为null值建立索引。

使用null_value搜索null值的记录

要想搜索null值文档,就要为null值创建索引。
一个方法是用一个特定值替换掉null值,比如用0来代替员工id不存在,搜索时直接使用特定值去搜索。
另一个方法是使用es提供的null_value功能。
在定义映射的时候指定null_value

"employee_id":{
    "type":"long",
    "null_value":0
}

注意: null_value的值要和字段数据类型一致。
这样在索引记录的时候,es发现employee_id为null值,就会将这个文档归属到null_value指向的记录集中,本例是0。
但是es不会修改文档的原值, 所以在文档中, employee_id仍然为null值。
搜索的时候,就可以使用null_value值去搜索employe_id为null的文档。
例如:

get /dev-member/_search
{
  "query":{
    "term": {
      "employee_id": 0
    }
  }
}

返回的数据中 employee_id为null

{
  "took": 873,
  "timed_out": false,
  "_shards": {
    "total": 3,
    "successful": 3,
    "skipped": 0,
    "failed": 0
  },
  "hits": {
    "total": {
      "value": 1,
      "relation": "eq"
    },
    "max_score": 1,
    "hits": [
      {
        "_index": "dev-member",
        "_id": "1234",
        "_score": 1,
        "_source": {
          "user_id": "1234",
          "employee_id": null
        }
      }
    ]
  }
}

null_value不是指定默认值

一开始,我以为这是个默认值,也被gpt误导了,后面发现根本不是一回事。
如果在索引文档的时候,没有指定某个字段,那这个字段就不会存在文档中,使用null_value搜索是搜索不出来的,这时候要用exists搜索。

总结

  1. 在映射中可以指定字段的null_value, 当字段的值为null值时,es会使用null_value为此字段创建索引,但不会替换文档中的null值,客户端可以使用null_value搜索文档。
  2. 如果索引文档的时候,没有包含某字段,那null_value搜索也无法找到此记录,可以使用exists来搜索。

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

相关文章:

  • Python_爬虫3_Requests库网络爬虫实战(5个实例)
  • 【模板】字典树luoguP8306
  • 每行数据个数在变的二维数组的输出
  • IPv6 NDP 记录
  • 【Android、IOS、Flutter、鸿蒙、ReactNative 】启动页
  • 【JAVA】使用IDEA创建maven聚合项目
  • esp8266固件烧录用户手册
  • mac系统u盘启动盘制作教程,更新至macOS Sonoma 14
  • Xilinx的FIR滤波器IP的设计与仿真
  • Django 注册及创建订单商品
  • fl studio21水果新手要不要购买?
  • 推荐一款适合科技行业的CRM系统
  • 电脑定时关机
  • HTTP发起请求与收到响应的大致过程
  • N-129基于springboot,vue学生宿舍管理系统
  • Flink几个性能调优
  • 关于JAVA中字节码文件版本号、产品版本号及开发版本号的关系
  • 0基础学习PyFlink——用户自定义函数之UDTF
  • 机器学习-朴素贝叶斯之多项式模型
  • Pytorch公共数据集、tensorboard、DataLoader使用
  • 揭秘!新手主播如何快速出圈,看拓世法宝分分钟打造百万直播间
  • uniapp开发小程序—picker结合后台数据实现二级联动的选择
  • win10 + VS2017 编译libjpeg(jpeg-9b)--更新
  • Ansible playbook的block
  • 229. 多数元素 II
  • 【HarmonyOS】元服务卡片router实现跳转到指定页面并传动态参数