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": {}}
}

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...