ElasticSearch(二):Mapping

一 自定義mapping

  • Mapping類似于數(shù)據(jù)庫中表定義伟阔,定義Index字段名搭综,字段類型及倒排索引相關配置;
  • Mapping中字段類型一旦設定后站辉,禁止修改呢撞,若修改,重新建立新索引饰剥,進行reindex操作殊霞;
  • 通過dynamic參數(shù)控制字段新增,參數(shù)有true/false/strict汰蓉;
##dynamic控制字段新增
##true:默認允許自動新增字段绷蹲; false:不允許自動新增字段,文檔可以正常寫入顾孽,但是無法對該字段進行查詢祝钢;strict:文檔不能寫入;
PUT my_index
{
  "mappings": {
    "doc": {
      "dynamic":false,
      "properties": {
        "title": {
          "type": "text"
        },
        "name": {
          "type": "keyword"
        },
        "age": {
          "type": "integer"
        }
      }
    }
  }
}
GET my_index/_mapping
PUT my_index/doc/1
{
  "title":"hello,world",
  "desc":"nothing here" ##dynamic為false岩齿,可以添加文檔太颤,但是不能查詢該字段苞俘;
}

二 常用參數(shù)設置

  • copy_to
    將該字段的值復制到目標字段盹沈,不會出現(xiàn)在_source中,只用來搜索吃谣;
PUT my_index
{
  "mappings": {
    "doc": {
      "properties": {
        "first_name": {
          "type": "text",
          "copy_to": "full_name" 
        },
        "last_name": {
          "type": "text",
          "copy_to": "full_name" 
        },
        "full_name": {
          "type": "text"
        }
      }
    }
  }
}
PUT my_index/doc/1
{
  "first_name": "John",
  "last_name": "Smith"
}
GET my_index/_search
{
  "query": {
    "match": {
      "full_name": {  ##full_name中同時包含John和Smith
        "query": "John Smith",
        "operator": "and" 
      }
    }
  }
}
  • index
    控制當前字段是否時索引乞封,默認為true,即記錄索引岗憋,false不記錄肃晚,即不可搜索;
PUT my_index
{
  "mappings": {
    "doc": {
      "properties": {
        "cookie": {
          "type": "text",
          "index": false
        }
      }
    }
  }
}
PUT my_index/doc/1
{
  "cookie":"name=alfred"
}
GET my_index/_search
{
  "query":{
    "match": {
      "cookie": "name" ##Cannot search on field [cookie] since it is not indexed
    }
  }
}
  • index_options
    用于控制倒排索引記錄的內容仔戈;
docs: 記錄doc id
freqs: 記錄doc id 和 term frequencies
positions: 記錄doc id/term frequencies/term position
offsets: 記錄doc id/term frequencies/term position/character offsets
  • null_value
    當字段遇到null值時的處理策略关串,默認為null拧廊,即空值,es會自動忽略晋修,可以通過設定該字段的默認值吧碾;
PUT my_index
{
  "mappings": {
    "my_type": {
      "properties": {
        "status_code": {
          "type":       "keyword",
          "null_value": "NULL" 
        }
      }
    }
  }
}
PUT my_index/my_type/1
{
  "status_code": null
}
PUT my_index/my_type/2
{
  "status_code": [] 
}
GET my_index/_search
{
  "query": {
    "term": {
      "status_code": "NULL" 
    }
  }
}

三 數(shù)據(jù)類型

  • 核心數(shù)據(jù)類型
字符串型: text(分詞) keyword
數(shù)值型: long integer short byte double float half_float scaled_float
日期類型: date
布爾類型: boolean
二進制類型: binary
范圍類型: integer_range float_range long_range double_range date_range
  • 復雜數(shù)據(jù)類型
 數(shù)組類型: array
 對象類型: object
 嵌套類型: nested object
  • 地理位置數(shù)據(jù)類型
geo_point
geo_shape
  • 專用類型
記錄ip地址: ip
實現(xiàn)自動補全: completion
記錄分詞數(shù): token_count
記錄字符串hash值: murmur3
percolator
join
  • 多字段特性
允許對用一個字段采用不同的配置,比如分詞墓卦,常見例子如對任命實現(xiàn)拼音搜索倦春,僅需再人名中增加pinyin子字段即可;

四 Dynamic Mapping

  • 自動根據(jù)Json類型轉換為ES類型
  • 日期自動識別
dynamic_date_formats:自定義日期類型
PUT my_index
{
  "mappings":{
    "my_type":{
      "dynamic_date_formats":["MM/dd/yyyy"]
    }
  }
}
不定義mapping落剪,添加文檔后的日期格式識別為text類型
  • 數(shù)字自動識別
numeric_detection: 開啟字符串中數(shù)字自動識別
##將字符串中的數(shù)字識別為數(shù)值類型
PUT my_index
{
  "mappings":{
    "my_type":{
      "numeric_dectection":true
    }
  }
}
PUT my_index/my_type/1
{
  "my_float":"1.0",
  "my_integer":"1"
}
  • Dynamic Templates
允許根據(jù)es自動識別的數(shù)據(jù)類型/字段名等來動態(tài)設定字段類型睁本;
##match_mapping_type匹配自動識別字段類型,match忠怖,unmatch匹配字段名呢堰,path_match,path_unmath匹配路徑
PUT my_product_index
{
  "mappings": {
    "doc": {
      "dynamic_templates": [
        {
          "strings": {
            "match_mapping_type": "string",
            "mapping": {
              "type": "keyword"
            }
          }
        }
      ]
}

五 Index Template

  • 用于在新建索引時自動應用預先設定的配置凡泣,簡化所以創(chuàng)建暮胧,若有多個模板,根據(jù)order大小问麸,大的會覆蓋掉小的往衷;
PUT _template/test_template
{
  "index_patterns": ["te*", "bar*"],
  "order":0,
  "settings": {
    "number_of_shards": 1
  },
  "mappings": {
    "doc": {
      "_source": {
        "enabled": false
      },
      "properties": {
        "name": {
          "type": "keyword"
        }
      }
    }
  }
}
PUT _template/test_template2
{
  "index_patterns": ["test*"],
  "order":1,
  "settings": {
    "number_of_shards": 1
  },
  "mappings": {
    "doc": {
      "_source": {
        "enabled": true
      }
    }
  }
}
PUT test_index
GET test_index/ ##order大的會覆蓋小的
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市严卖,隨后出現(xiàn)的幾起案子席舍,更是在濱河造成了極大的恐慌,老刑警劉巖哮笆,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件来颤,死亡現(xiàn)場離奇詭異,居然都是意外死亡稠肘,警方通過查閱死者的電腦和手機福铅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來项阴,“玉大人滑黔,你說我怎么就攤上這事』防浚” “怎么了略荡?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長歉胶。 經常有香客問我汛兜,道長,這世上最難降的妖魔是什么通今? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任粥谬,我火速辦了婚禮肛根,結果婚禮上,老公的妹妹穿的比我還像新娘漏策。我一直安慰自己晶通,他們只是感情好,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布哟玷。 她就那樣靜靜地躺著狮辽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪巢寡。 梳的紋絲不亂的頭發(fā)上喉脖,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天,我揣著相機與錄音抑月,去河邊找鬼树叽。 笑死,一個胖子當著我的面吹牛谦絮,可吹牛的內容都是我干的题诵。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼层皱,長吁一口氣:“原來是場噩夢啊……” “哼性锭!你這毒婦竟也來了?” 一聲冷哼從身側響起叫胖,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤草冈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后瓮增,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體怎棱,經...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年绷跑,在試婚紗的時候發(fā)現(xiàn)自己被綠了拳恋。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡砸捏,死狀恐怖谬运,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情带膜,我是刑警寧澤吩谦,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站膝藕,受9級特大地震影響,放射性物質發(fā)生泄漏咐扭。R本人自食惡果不足惜芭挽,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一滑废、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧袜爪,春花似錦蠕趁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至昙篙,卻和暖如春腊状,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苔可。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工缴挖, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人焚辅。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓映屋,卻偏偏與公主長得像,于是被迫代替她去往敵國和親同蜻。 傳聞我的和親對象是個殘疾皇子棚点,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內容

  • Mapping 類似于數(shù)據(jù)庫中的表結構定義,主要作用如下: 定義Index下字段名(Field Name) 定義字...
    小旋鋒的簡書閱讀 17,919評論 0 14
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理湾蔓,服務發(fā)現(xiàn)乙濒,斷路器,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 2018年10月12日 天氣晴轉陰 1 最近在讀武志紅的《夢知道答案》卵蛉。其中有句話打動了我:...
    韓依妍閱讀 435評論 2 3
  • 【今日話題】你一天中完全屬于自己的時間有多少傻丝? 一天時間甘有,其實除了工作外,都是自己的葡缰,但是有的時間在路上亏掀,在做飯,...
    盆叔閱讀 103評論 0 0
  • 有一種生活叫做:不論這個世界多么的污濁泛释,我依然會保持自己那份圣潔滤愕!不論別人的思想如何卑微,我依然繼續(xù)擁有著一份善心...
    從容一生Lily閱讀 170評論 0 0