推广 热搜: 未来    中国  企业  服务  政策  公司  快速  上海  设备 

ES 【4】DSL 搜索 : term精确搜索与match分词、match_phrase最低精度、boost权重、布尔查询boolQuery、filter过滤器、sort排序

   日期:2024-11-05     作者:caijiyuan    caijiyuan   评论:0    移动:http://xiaoguoguo.dbeile.cn/mobile/news/457.html
核心提示:查询搜索的规范:        在索引后加上  _search  ;         ?q  代表是query   ;

查询搜索的规范

ES 【4】DSL 搜索 : term精确搜索与match分词、match_phrase最低精度、boost权重、布尔查询boolQuery、filter过滤器、sort排序

        在索引后加上  _search  ; 

        ?q  代表是query   

        基于 desc 字段是查询

多条件查询

        DSL 搜索,查询条件使用 josn格式。

exists  查询某个字段是否存在   query  代表查询

  添加  from   size 关键字。 from 是第几条 ; size 每页多少条。  

term  搜索的时候会把用户搜索内容,比如“慕课网”作为一整个关键词去搜索,而不会对其进行分词后再搜索。  

match 会对 慕课网 先进行分词(其实就是全文检索,在查询,而term则不会,直接把 慕课网 作为一个整的词汇去搜索。match 搜索,比如 desc字段中有一个 “课” ,比如是 “上课” 就可以被搜索到。而 term 则必须是 “慕课网” 才可以被搜索到

match:分词后只要有匹配就返回

match_phrase:分词结果必须在text字段分词中都包含,而且顺序必须相同,而且必须都是连续的。(搜索比较严格

slop:允许词语间跳过的数量

 operator

  • or:搜索内容分词后,只要存在一个词语匹配就展示结果
  • and:搜索内容分词后,都要满足词语匹配

minimum_should_match

  •  minimum_should_match :最低匹配精度,至少有[分词后的词语个数]x百分百,得出一个数据值取整。举个例子:当前属性设置为 70% ,若一个用户查询检 有10个词语,那么匹配度按照 10x70%=7,则desc中至少需要有7个词语匹配,就展示;若分词后有8个,则 8x70%=5.6,则desc中至少需要有5个词语匹 示。 ‘
  • minimum_should_match 也能设置具体的数字,表示个数

根据 ids 来查询

”慕课网“ 在 desc ; nickname 两个字段中查询

提升字段权重   使用   ^ 

可以组合多重查询

  • must:查询必须匹配搜索条件,譬如 and
  • should:查询匹配满足1个以上条件,譬如 or
  • must_not:不匹配搜索条件,一个都不要满足。(里面多条件也是 and 形式,既不满足A条件,也不满足B条件,也不满足C条件
  • 这3个关键字,可以组合一起使用

这3个查询内容都是已数组方式传入

 列如,    must  即 字段 “desc” 和 “nickname” 包含 “慕课网” 字段 并且 sex=1

boost 为词汇查询加权重

数值越大,权重越高。搜索后,有个 _score 值就越高,搜索出来的排名也就会越高

对搜索出来后的数据作过滤。

对搜索出来的结果进行数据过滤。不会到es库里去搜,不会去计算文档的相关度分数,所以过滤的性能会比较高,过滤器可以和全文搜索结合在一起使用。 post_filter元素是一个顶层元素,只会对搜索结果进行过滤。不会计算数据的匹配度相关性分数,不会根据分数去排序,query则相反,会计算分数,也会按照分 使用场景

  • query:根据用户搜索条件检索匹配记录
  • post_filter:用于查询后,对结果数据的筛选
  • gte:大于等于
  • lte:小于等于
  • gt:大于
  • lt:小于

对查询的数据筛选   money字段在 55.8 ~ 155.8的区间

对查询的数据,进行排序。排序一般对数值排序, 文本的排序一般不多

  • asc   正序
  • desc  倒叙 

数值、keyword 都可以做排序。 

text 文本不能做排序,因为做了分词。要给text字段做排序,需要给它添加一个附属属性。

如下, name 类型是 text , 但是又给它一个附属属性 keyword

 当需要对 text 类型的字段做排序时 就是   字段.keyword。 如下

加上 highlight 标签。

    "pre_tags": ["<tag>"],
    "post_tags": ["</tag>"],

本文地址:http://xiaoguoguo.dbeile.cn/news/457.html    多贝乐 http://xiaoguoguo.dbeile.cn/ , 查看更多
 
 
更多>同类行业资讯
0相关评论

新闻列表
企业新闻
推荐企业新闻
推荐图文
推荐行业资讯
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2023001713号