ES: 设置默认值
创始人
2024-06-03 16:39:34
0

场景: 

   XX对象的告警个数字段是数字, 优先级字段是数字

  排序要求: 优先告警个数大->小, 其次优先级大->小

问题: 

告警个数字段不存在或者值为0的情况是等价的,排序上应该是平等的.

不应该存在0的大于字段不存在的

处理: 

    对没有告警个数字段的默认设置0 , 那么排序的时候才正确

    使用Missing - 给字段设置默认值

一般用于排序时,该字段没有值,使用missing赋值默认值,然后就用赋的值进行排序

GET indexname/_search
{"sort": [{"alarmNum": {"order": "asc","missing": 0    -- 此字段不存在的时候, 值为0 . 与值0是一样排序 }},{"priority_code":{"order": "asc"}}],"from":0,"size":100
}

unmapped_type - 容错不存在的字段

如果mapping中无此字段,则搜索请求将失败.unmapped_type选项允许您忽略没有mapping的字段,也不按它们排序。参数的值为该字段对应值的类型。

这种场景一般不存在.因为index至少有一条数据存在此字段有值,mapper里面就有

如何不报错?

GET project_base_info/_search
{"sort": [{"alarmNum1": {"order": "asc","missing": 0,"unmapped_type":"long"  -- 有了此配置 ,mapper没有也不会报错}},{"project_priority_code":{"order": "asc"}}],"from":0,"size":100
}

pipeline 设置默认值:属于前置设置默认值

在插入数据时候,给字段设置给默认值. 但问题是,后续也无法修改此字段. 这个应该很少有这个需求

PUT _ingest/pipeline/add_zcy_pipeline
{"processors": [{"set": {"field": "projectCode","value": "10000000"}}]
}设置projectCode 默认值10000000创建索引:
PUT projecy_zcy3
{"settings": {"refresh_interval": "1s","number_of_shards": 1,"number_of_replicas": 1,"index":{"default_pipeline":"add_zcy_pipeline"}},"mappings": {"properties": {"id": {"type": "text","fields": {"keyword": {"type": "keyword"},"keylong": {"type": "long"}}},"projectCode": {"type": "text"},"projectName": {"type": "text","fields": {"keyword": {"type": "keyword"}}},"projectStatus": {"type": "keyword"}}}
}插入数据
PUT projecy_zcy3/_doc/2
{"id":"1022","projectName":"ssss"
}
结果:"_source" : {"projectCode" : "10000000","id" : "1022","projectName" : "ssss"}
PUT projecy_zcy3/_doc/2
{"id":"1022","projectName":"ssss","projectCode":"111"
}
结果还是"_source" : {"projectCode" : "10000000","id" : "1022","projectName" : "ssss"}

设置默认值--script执行批量

# 批量更新脚本
POST customer/_update_by_query
{"script": {"lang": "painless","source": "if (ctx._source.major == null) {ctx._source.major = 'student'}"}
}

设置默认值--借助 pipeline script 更新

PUT _ingest/pipeline/update_pipeline
{"processors": [{"script": {"lang": "painless","source": """if (ctx['major'] == null) {ctx['major'] = 'student'}"""}}]
}
POST customer/_doc/4
{"major":null
}
POST customer/_update_by_query?pipeline=update_pipeline
{"query": {"match_all": {}}
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...