zoukankan      html  css  js  c++  java
  • es mapping设置之text or keyword

    前言:
        在es 2.*版本里面是没有这两个字段,只有string字段。

        5.*之后,把string字段设置为了过时字段,引入text,keyword字段

    那么今天我们来看一下,es在5.*之后,字符串类型的mapping应该怎么设置 

    实践:
    准备工作:

    es在5.*之后,string类型常用三种,

    1.默认的,就是我们不设置mapping直接往里面插入数据 

    2.我们设置mapping为text

               

    3.我们设置mapping为keyword,将2里面的text改为keyword 

    4.我们分别往里面添加一个字段 name:张三李四,然后分别查找张三

           添加:     查找:     

    结论一:我们发现类型为keyword的无法查找,可以得出keyword不支持分词查询 ,但另外两个支持 

    5.我们继续三个索引里面继续添加姓名(添加几个一样的),此时我们要统计姓名相同的人的人数,那么我们必须用到聚合查询 

    查询text索引时,直接说不行 

    查询xuzhan索引时,要在聚合字段加一个keyword就行

    查询key时,可以 

    结论二:text类型无法聚合查询 

    那么至此我们可以总结出这三个在查询上的优缺点了

    总结
      分词 聚合
    keyword 不支持 支持
    text 支持 不支持
    默认 支持 支持
    此时的你是不是在想那以后就直接用默认类型就行了,万能的,但是,但是,但是

      经过上面的测试,可以发现text类型在存储数据的时候会默认进行分词,并生成索引。而keyword存储数据的时候,不会分词建立索引,显然,这样划分数据更加节省内存。为了性能考虑,我们应该仔细斟酌一下 text or keyword ?

  • 相关阅读:
    心理学安全威胁
    设计模式是在运用构造定律
    分形理论
    构造定律
    [SOA]REST与SOA两种架构的异同比较
    加法是自然之道
    ES : 软件工程学的复杂度理论及物理学解释
    软件架构的灵活设计
    软件复杂度与结构:(影响复杂度的因素)
    socket 的通信过程
  • 原文地址:https://www.cnblogs.com/sea520/p/11881037.html
Copyright © 2011-2022 走看看