ElasticSearch7之function_socre使用心得

2023-10-27

介绍:
1、function_score是可以修改查询检索文档的分数,使用function_score必须定义​​一个查询和一个或多个函数,为查询返回的每个文档计算一个新的分数。

function_score提供的评分函数:
1、weight : 设置一个float类型的权重值,使最终分数是查询分数与该权重值的乘积

2、field_value_factor : 允许使用文档中的字段来影响分数

GET /_search
{
  "query": {
    "function_score": {
      "field_value_factor": {
        "field": "my-int",
        "factor": 1.2,
        "modifier": "sqrt",
        "missing": 1
      }
    }
  }
}

field:要从文档中提取的字段(相乘的字段,该字段必须是数字类型)。
factor:与字段值相乘的可选因子,默认为1。
modifier:应用于字段值的修饰符,可以是以下之一:none、log、 log1p、log2p、ln、ln1p、ln2p、square、sqrt、 或reciprocal。默认为none(参考官网解释:这里

3、random_score : 为每个用户都使用一个不同的随机评分

4、decay functions(衰减函数,如:linear、exp、guass):以某个字段的值为基准,距离某个值越近得分越高

5、script_score : 自定义脚本函数控制评分计算

function_score参数解释:
1、boost_mode : 决定查询分数和评分函数计算出来的分数如何合并,默认相乘(multiply,sum,min,max,replace)

2、score_mode : 决定functions里面的评分函数之间的分数如何合并,默认相乘(multiply,sum,min,max,avg,first(使用首个函数))

function_socre查询模板:

1、单个评分函数:

GET /_search
{
    "query": {
        "function_score": {
            "query": {.....}, //主查询,查询完后这裡自己会有一个评分,就是查询分数
            "field_value_factor": {...}, //在查询分数的基础上,给他加上评分函数计算出来的分数,如果只有一个评分函数时,直接将评分函数写在query下面就可以了
            "boost_mode": "multiply", //決定查询分数和评分函数分数怎么合并
            "max_boost": 1.5 //限制评分函数计算出来的最高分,但是不会限制查询分数
        }
    }
}

2、多个评分函数(用functions包含这些函数)

GET /_search
{
  "query": {
    "function_score": {
      "query": { "match_all": {} },
      "functions": [
        {
          "filter": { "match": { "test": "bar" } },
          "random_score": {}, 
          "weight": 23
        },
        {
          "filter": { "match": { "test": "cat" } },
          "weight": 42
        },
	{
	"script_score": {
        "script": {
          "source": "Math.log(2 + doc['my-int'].value)"
        }
      }
	}
      ],
      "max_boost": 42,
      "score_mode": "max",
      "boost_mode": "multiply",
      "min_score": 42
    }
  }
}

特别注意:

1、如果查询条件中存在距离过滤的,查询分数为0,如果不指定boost_mode的分数合并方式(默认相乘),则计算出来的分数都是0,如下:(纠正一下,无意间看到一篇文章说“在一个查询语句里面可以同时存在queryfilter,只不过只有query的查询字段会进行相关性_score的计算,而filter仅仅用来筛选”,所以这里造成查询分时为0并不是filter的原因,而是must:[]的原因)

{
    "query":{
    "function_score":{
        "query":{
           "bool":{
               "must":[],
               "filter":{
                   "geo_distance":{
                       "distance":"200km",
                       "location":{
                           "lat":23.31231,
                           "lon":120.231231
                        }
                    }
                }
            }         
        },
        "functions":[
           {
               "filter":{"match":{"test": "bar"}},
               "weight":20          
            },
           {
               "script_score":{
                   "script":{
                       "lang":"painless",                       
                       "params":{"value":20},                       
                       "inline":"Math.log(2 + doc['my-int'].value*params.value)"                    
                       }
               }
           }
       ],
        "score_mode":"sum"
	//"boost_mode":"sum"    
       }
    },
    "from":0,
    "size":5,
    "sort" : [{"_score" : "asc" }],
    "explain": true
}

结果:

2、ES6.5版本之后(本文对应的es版本是7.10),weight不能为负值,且如果评分函数计算出来的值为负数,ES会自动过滤掉对应的数据。

3、Elasticsearch中,内置了很多分词器(analyzers),默认是standard 分词器

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ElasticSearch7之function_socre使用心得 的相关文章

随机推荐

  • 运动目标检测--光流法

    一 概述 运动目标检测是指当监控场景中有活动目标时 采用图像分割的方法从背景图像中提取出目标的运动区域 运动目标检测技术是智能视频分析的基础 因为目标跟踪 行为理解等视频分析算法都是针对目标区域的像素点进行的 目标检测的结果直接决定着智能视
  • maven私服搭建

    文章目录 前言 一 Nexus 二 安装nexus 2 1在Mac终端输入 如果提示没有brew命令 请先安装brew 2 2启动nexus 2 3访问web管理系统 三 nexus的配置 3 1登录后开始设置操作 3 1 1设置新密码 3
  • 笔记/Linux运维面试常见问题

    linux基础 linux的特点 免费 开源 单根目录树 多用户多任务 区分大小写 一切皆文件 不以扩展名区分文件类型 Linux的必须分区有哪些 根分区 swap分区 swap分区的作用 物理内存不足时 未使用的进程可以临时保存到swap
  • 浅谈EL表达式

    目录 EL表达式 什么是EL表达式 EL表达式的语法 EL表达式中的查找并输出 EL运算符 EL算数运算符 EL比较运算符 EL逻辑运算符 EL其他运算符 EL表达式 什么是EL表达式 EL 提供了更为简洁 方便的形式来访问变量和参数 不仅
  • 黑盒测试-等价类划分法与边界值分析法-三角形问题

    等价类划分法 等价类划分可以把全部输人数据合理划分为若干等价类 在每一个等价类中取个数据作为测试的输人条件 就可以用少量代表性的测试数据取得较好的测试效果 有效等价类 指对于程序规格说明来说 由合理的 有意义的输入数据构成的集合 利用它 可
  • 对于傅里叶变换的小结

    原本写在word中 含有一些公式不容易搬移 因此输出长图发布在博客中 个人理解有限 如有错误欢迎交流指出 关于参数化谱估计可以参考我以前的几篇博客 Yule Walker方程法参数化谱估计 Python实现版 Levinson Durbin
  • Ceres与colmap安装

    已在ubuntu18 04上成功安装ceres1 14 0和colmap ceres1 14 0基本没错 找tag里的1 14 0压缩包 因为复制的git链接都指定了下载最新版本 colmap 安装cmakelist 添加set CMAKE
  • 深入了解C/C++开发就业前景如何?

    C C 编程语言 作为编程行业里出现较早的编程语言 几十年来 因为语言灵活 数据结构丰富 具有结构化 平台移植力强 程序执行效率高等特点 广受关注与应用 深入了解C C 开发就业前景如何 即使新编程语言不断涌出 智能化水平越来越高 也无法挑
  • 牧师与恶魔过河游戏——智能提示

    前言 这次实现一个含提示功能的牧师与恶魔过河小游戏 主要在上一个版本的牧师与恶魔小游戏上进行更改 通过增加一个状态计算和改版了得寻路算法 实现向玩家提示如何胜利完成游戏 游戏主体实现思路见上一篇博客 牧师与恶魔小游戏 动作分离版 游戏效果图
  • 考研英语二大作文模板/图表作文,英语图表作文这一篇就够了

    常见图表类型 表格 它表示多种事物的相互关系 曲线 它常表示事物的变化趋势 柱状 它用来表示几种事物的变化情况及相互关系 饼状 表示各事物在总体中所占的比例及相互关系 其中 柱形图和饼形图出现的频率比较高 图表作文结构 Para 1 描述图
  • 电动车结构及其工作原理

    电动车结构及其工作原理 文章目录 电动车结构及其工作原理 电动车定义 电动车结构 电源系统 电力驱动系统 整车控制器 辅助系统 电动车可能存在的结构形式 电动车定义 纯电动汽车是完全由可充电电池 如铅酸电池 镍镉电池 镍氢电池或锂电子电池
  • Ubuntu更改下载源

    Ubuntu更改下载源 今天美滋滋的打开ubuntu准备下载一个语言包 对于英语不好的我来说 看全英文版的ubuntu系统太吃力了 感觉系统极其不友好 哈哈 然后准备下在一个语言包 但是下载速度及其的慢 只有十几kb每秒 如果按照这样的速度
  • FastAPI利用装饰器实现定时任务

    因为 FastAPI 本身就是高性能异步框架 所以在不使用任何第三方定时任务模块的情况下 FastAPI 也可以很方便的实现定时任务 创建一个 tasks py 文件 复制下面的装饰器代码 import asyncio from logur
  • MyBatis详细执行流程

    目录 MyBatis详细的执行流程 1 创建加载核心配置文件的inputStream流 1 1 Recourse getResourceAsStream String resource 方法 1 2 getResourceAsStream
  • React中使用CSS样式的五种方法,主流推荐CSS Modules和Styled Components

    前言 由于 React的JSX语法 能在React中使用样式的方式有很多 本文主要介绍在React中经常使用CSS样式的五种方法 1行内样式 2声明样式 3引入样式 4 CSS Modules模块化 5 Styled component 1
  • DolphinScheduler3.0.1(数据质量)

    DolphinScheduler3 0 1 数据质量 Refer 1 data quality jar包修改 1 配置文件修改 2 依赖不明确问题 3 scope多修改问题 2 实现方式 1 Spark提交 2 结构解析 1 图1 2 图2
  • Blender一些建模技巧与应用

    平滑卡线 加线 卡结构线 加线 时 按E均匀线条会使加线与边线均匀对齐 投影切割 投影切割 使用调形后的曲线 放到模型表面上方进行投影切割 投影形状是 曲线范围内所能看到的模型 就是切割后的形状 使用流程 1 调整好曲线与屏幕的角度 想完全
  • 并行计算之OpenMP简介

    OpenMP环境安装 基于ubuntu20 04 sudo apt get update sudo apt get install libomp dev OpenMP概述 面向多线程并行编码的编译指导语句 如 pragma omp para
  • ssh连接远程主机执行脚本的环境变量问题

    近日在使用ssh命令ssh user remote myscript sh登陆到远程机器remote上执行脚本时 遇到一个奇怪的问题 myscript sh line n app command not found app是一个新安装的程序
  • ElasticSearch7之function_socre使用心得

    介绍 1 function score是可以修改查询检索文档的分数 使用function score必须定义 一个查询和一个或多个函数 为查询返回的每个文档计算一个新的分数 function score提供的评分函数 1 weight 设置