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 格式的字符串

猜你喜欢

转载自www.cnblogs.com/wjx-blog/p/12076700.html