zoukankan      html  css  js  c++  java
  • Elasticsearch学习笔记之—mapping

    创建mapping

    PUT test_index
    {
      "mappings": {
        "_doc": {
          "properties": {
            "name":{
              "type":"text"
            },
            "age": {
              "type": "integer"
            },
            "birth_day": {
              "type": "date", 
              "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"
            }
          }
        }
      }
    }

    查看mapping

    GET /test_index/_mapping

    插入数据

    PUT test_index/_doc/1
    {
      "name":"1A",
      "age":22,
      "birth_day":"2019-12-21"
    }

    查询

    GET /test_index/_search

    数据类型

      • 字符串 - text

    用于全文索引,该类型的字段将通过分词器进行分词,最终用于构建索引

      • 字符串 - keyword

    不分词,只能搜索该字段的完整的值,只用于 filtering

      • 数值型

    long:有符号64-bit integer:-2^63 ~ 2^63 - 1
    integer:有符号32-bit integer,-2^31 ~ 2^31 - 1
    short:有符号16-bit integer,-32768 ~ 32767
    byte: 有符号8-bit integer,-128 ~ 127
    double:64-bit IEEE 754 浮点数
    float:32-bit IEEE 754 浮点数
    half_float:16-bit IEEE 754 浮点数
    scaled_float

      • 布尔 - boolean

    值:false, “false”, true, “true”

      • 日期 - date

    由于Json没有date类型,所以es通过识别字符串是否符合format定义的格式来判断是否为date类型
    format默认为:strict_date_optional_time||epoch_millis format

      • 二进制 - binary

    该类型的字段把值当做经过 base64 编码的字符串,默认不存储,且不可搜索

      • 范围类型

    范围类型表示值是一个范围,而不是一个具体的值
    譬如 age 的类型是 integer_range,那么值可以是 {“gte” : 10, “lte” : 20};搜索 “term” : {“age”: 15} 可以搜索该值;搜索 “range”: {“age”: {“gte”:11, “lte”: 15}} 也可以搜索到
    range参数 relation 设置匹配模式
    INTERSECTS :默认的匹配模式,只要搜索值与字段值有交集即可匹配到
    WITHIN:字段值需要完全包含在搜索值之内,也就是字段值是搜索值的子集才能匹配
    CONTAINS:与WITHIN相反,只搜索字段值包含搜索值的文档
    integer_range
    float_range
    long_range
    double_range
    date_range:64-bit 无符号整数,时间戳(单位:毫秒)
    ip_range:IPV4 或 IPV6 格式的字符串

  • 相关阅读:
    大数据基础1
    java之MySQL的使用
    java反射
    java多线程
    java异常
    指针综合
    指向函数的指针变量做函数的参数
    指向函数的指针
    字符串指针法赋值
    字符串冒泡排序和折半查找
  • 原文地址:https://www.cnblogs.com/wjx-blog/p/12076700.html
Copyright © 2011-2022 走看看