下载APP
登录
关闭
讲堂
算法训练营
Python 进阶训练营
企业服务
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 27 | Query&Filtering与多字符串多字段查询
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看

Elasticsearch核心技术与实战

共100讲 · 约1000分钟
16623
免费
01 | 课程介绍
免费
02 | 内容综述及学习建议
免费
03 | Elasticsearch简介及其发...
免费
04 | Elastic Stack家族成员及...
免费
05 | Elasticsearch的安装与...
06 | Kibana的安装与界面快速...
07 | 在Docker容器中运行Elas...
08 | Logstash安装与导入数据
09 | 基本概念:索引、文档和...
10 | 基本概念:节点、集群、分...
11 | 文档的基本CRUD与批量操...
12 | 倒排索引介绍
13 | 通过Analyzer进行分词
14 | Search API概览
15 | URI Search详解
16 | Request Body与Query ...
17 | Query String&Simple ...
18 | Dynamic Mapping和常见...
19 | 显式Mapping设置与常见参...
20 | 多字段特性及Mapping中配...
21 | Index Template和Dynami...
22 | Elasticsearch聚合分析简...
23 | 第一部分总结
24 | 基于词项和基于全文的搜索
25 | 结构化搜索
26 | 搜索的相关性算分
27 | Query&Filtering与多字...
28 | 单字符串多字段查询:Dis...
29 | 单字符串多字段查询:Mult...
30 | 多语言及中文分词与检索
31 | Space Jam,一次全文搜索...
32 | 使用Search Template和In...
33 | 综合排序:Function Scor...
34 | Term&Phrase Suggester
35 | 自动补全与基于上下文的提...
36 | 配置跨集群搜索
37 | 集群分布式模型及选主与脑...
38 | 分片与集群的故障转移
39 | 文档分布式存储
40 | 分片及其生命周期
41 | 剖析分布式查询及相关性算...
42 | 排序及Doc Values&Field...
43 | 分页与遍历:From, Siz...
44 | 处理并发读写操作
45 | Bucket & Metric聚合分...
46 | Pipeline聚合分析
47 | 作用范围与排序
48 | 聚合分析的原理及精准度问...
49 | 对象及Nested对象
50 | 文档的父子关系
51 | Update By Query &...
52 | Ingest Pipeline & Pa...
53 | Elasticsearch数据建模实...
54 | Elasticsearch数据建模最...
55 | 第二部分总结回顾
56 | 集群身份认证与用户鉴权
57 | 集群内部安全通信
58 | 集群与外部间的安全通信
59 | 常见的集群部署方式
60 | Hot & Warm架构与Shard...
61 | 分片设计及管理
62 | 如何对集群进行容量规划
63 | 在私有云上管理Elasticsea...
64 | 在公有云上管理与部署Elas...
65 | 生产环境常用配置与上线清...
66 | 监控Elasticsearch集群
67 | 诊断集群的潜在问题
68 | 解决集群Yellow与Red的问...
69 | 提升集群写性能
70 | 提升进群读性能
71 | 集群压力测试
72 | 段合并优化及注意事项
73 | 缓存及使用Breaker限制内...
74 | 一些运维的相关建议
75 | 使用Shrink与Rollover AP...
76 | 索引全生命周期管理及工具...
77 | Logstash入门及架构介绍
78 | 利用JDBC插件导入数据到El...
79 | Beats介绍
80 | 使用Index Pattern配置数...
81 | 使用Kibana Discover探索...
82 | 基本可视化组件介绍
83 | 构建Dashboard
84 | 用Monitoring和Alerting监...
85 | 用APM进行程序性能监控
86 | 用机器学习实现时序数据的...
87 | 用机器学习实现时序数据的...
88 | 用ELK进行日志管理
89 | 用Canvas做数据演示
90 | 项目需求分析及架构设计
91 | 将电影数据导入Elasticsea...
92 | 搭建你的电影搜索服务
93 | 需求分析及架构设计
94 | 数据Extract & Enrichm...
95 | 构建Insights Dashboard
96 | Elastic认证介绍
97 | 考点梳理
98 | 集群数据备份
99 | 基于Java和Elasticseach构...
100 | 结束语
本节摘要
展开

精选留言(21)

  • 2019-08-21
    老师,结合您的视频和官方文档,现在知道有多种查询方式,包括:复合查询/全文本查询/term-level查询等,现在有一些混乱,比如 什么场景下用 boolen查询,什么场景下用match查询,又是什么场景下用term查询,这个我怎么去区分和使用呢?

    作者回复: 你可以自己对查询去做一些分类。

    例如terms查询是用于结构化数据的查询。全文用match查询。而bool属于一种复合查询。可以结合terms查询和match查询。

    我建议你先把查询相关的课都听一遍,然后在去尝试做分类。有一些查询是有功能上的重合的,自己去做了分类,可能更加容易加深理解。

    3
  • 2019-07-17
    老师,怎么解决多索引 关联查询?

    作者回复: 后面会讲父子关系的查询

    1
    3
  • 2019-08-07
    老师好,请问如何查靠近的数值。比如数据库里 小李5岁;小王8岁;小赵7岁。我想查最接近9岁的是谁

    作者回复: 这个可以用function score实现,看具体章节的视频

    1
    1
  • 2019-11-11
    老师,您好,在关于词频TF的介绍中,您这节课说的是搜索词在文档中出现的次数除以文档总字数,但是在12课的pdf中却说tf是搜索词在文档中出现的总次数,到底哪个是正确的?
  • 2019-11-08
    老师,在调整查询语句结构对相关度算分的内容里,测试下来bool子查询和无子查询的score是一样的。是我哪里理解错误了么?
  • 2019-11-07
    老师,_id是自定义的自增数字,请问能做range查询吗

    作者回复: 应该是不行的,如果你有这个需求,可以把这个id,映射到一个额外的字段,然后进行range查询

  • 问题:如下语句为什么文档三排名靠前?
    TF/IDF
    思考:
    1、每篇文档都包含apple,IDF应该一致
    2、apple在三个文档的TF,文档1是50%,文档2是50%,文档3是3/8小于50%,照这样计算,文档1和2应该比3靠前呀。


    POST /news/_bulk
    { "index": { "_id": 1 }}
    { "content":"Apple Mac" }
    { "index": { "_id": 2 }}
    { "content":"Apple iPad" }
    { "index": { "_id": 3 }}
    { "content":"Apple employee like Apple Pie and Apple Juice" }

    GET news/_search
    {
      "query": {
        "bool": {
          "must": [
            {
              "match": {
                "content": "apple"
              }
            }
          ]
        }
      }
    }

    GET _analyze
    {
      "analyzer": "standard",
      "text": "Apple employee like Apple Pie and Apple Juice"
    }
    展开
  • 2019-09-27
    老师
    elasticsearch filter已经忽略相关度评分了 为什么还要constant_score嵌套(我查了官网constant_score必须和filter结合使用)?
    1
  • 2019-09-20
    打卡,数据库最难最复杂的基本都是查询的功能,ES也不例外提供了各种各样的查询方式,使用不当会有性能问题,更次的会查不出自己想要的结果。这节值得反复看,先广后深,继续看,回头可以重点再看一遍。
  • 2019-09-01
    老师,如何验证filter是否走cache
  • 2019-08-27
    老师 post_filter与query和filter 区别是什么
    好像只能用
    GET star_document/_search
    {
      "post_filter": {
        "match": {
          "introduce": "测试"
        }
      }
    }
    不能用
    GET star_document/_search
    {
      "filter": {
        "match": {
          "introduce": "测试"
        }
      }
    }
    展开
  • 2019-08-08
    老师请问下,如何查出被包含的结果?比如传入参数gener:[comedy,romance].查出结果gener为[
  • 2019-08-07
    老师请问下,如何能查出被包含的结果?比如传入数组gener:[comedy,Romance] 查出gener为
  • 2019-08-06
    "query": {
        "bool": {
          "must": [
            {
              "query_string": {
                "default_field": "Name",
                "query": "阮一鸣"
              }
            }
          ]
        }
      }
    请问阮老师,假如我搜索的关键词是阮一鸣,但是返回给我的有三个同一个公司的阮一鸣,我该如何去重?
    展开

    作者回复: 一个公司有三个同名的员工,这不算去重吧?如果是同一个人,那就不应该重复写入。

    1
  • 2019-08-06
    老师:
    如果是这样写的filter会算分吗?
    {
      "query": {
        "bool": {
          "filter": [
            {
              "bool": {
                "should": [
                  { "term": { "productID.keyword": "xxx" } },
                  { "term": { "productID.keyword": "1111" } }
                ]
              }
            }
          ]
        }
      }
    }
    展开
    1
  • 2019-08-02
    POST /animals/_bulk
    { "index": { "_id": 1 }}
    { "text": "2 running Quick brown-foxes leap over lazy dogs in the summer evening." }

    POST /animals/_search
    {
      "query": {
        "bool": {
          "should": [
            { "term": { "text": "brown"}},
            { "term": { "text": "lazy"}},
            { "term": { "text": "quick"}},
            { "term": { "text": "dog"}}
          ]
        }
      }
    }
    无意中多执行了几次 _score 一会儿0.8630463 一会儿0.5469647 我用的版本都是7.2.0 这是我环境的问题吗? 我删了animals这个索引 然后多次执行index 重建并更新文档的版本 然后问题依然存在 分数还是会变一会儿0.86 一会儿0.54 "explain"=true 太长了 我就不贴出来了.
    展开

    作者回复: 查询相同的文档集,按理算分不会变的。
    除非
    1. 每次查询,你有增加或者删除文档
    2. 你的主分片书不是1,你每次删除全部数据,重新bulk写入后再做的查询

  • 2019-07-25
    学习打卡
  • 2019-07-20
    请问一下老师比如下面查询中的query就是今天讲的query上下文吗? 如果不是的话有啥区别呢?
    POST /testscore/_search
    {
      "query": {
        "match": {
          "content": "the elasticsearch"
        }
      }
    }
    展开

    作者回复: query和filter的区别在后续课程中会有讲解。

    例如在bool查询中,filter子句就属于filter,must_not也属于filter。

    你贴出的,属于是一个query。

    filter会使用cache,性能会更加好。

  • 2019-07-20
    请问一下老师相关性评分是怎样适用于yes | no 子句的, 是如果是yes就记做1, 是no就记做0吗, 还有yes | no 子句具体指代的是什么我不是很理解.
  • 2019-07-19
    请问老师,为什么bool.filter的score是0?有什么例子需要是0?
    我感觉1比较合适,旧版本的filtered.filter的score就是1。
    https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-bool-query.html#score-bool-filter