16 - Dynamic Mapping和常見類型字段

什么是Mapping

  • Mapping類似數(shù)據(jù)庫中的schema的定義,作用如下
    • 定義索引中的字段的名稱
    • 定義字段的數(shù)據(jù)類型瞄勾,例如字符串,數(shù)字鲸郊,布爾
    • 字段丰榴,倒排索引的相關配置,(Analyzed or Not Analyzed, Analyzer)
  • Mapping會把JSON文檔映射成Lucene所需要的扁平格式
  • 一個Mapping屬于一個索引的Type
  • 7.0開始秆撮,不需要再Mapping中指定type信息

字段的數(shù)據(jù)類型

  • 簡單類型
    • Text / Keyword
    • Date
    • Integer / Floating
    • Boolean
    • IPV4 & IPV6
  • 復雜類型:對象和嵌套類型
    • 對象類型 / 嵌套類型
  • 特殊類型
    • geo_point
    • geo_shape
    • percolator

什么是Dynamic Mapping

  • 在寫入文檔時候四濒,如果索引不存在,會自動創(chuàng)建索引
  • Dynamic Mapping的機制职辨,使得我們無需手動定義Mappings盗蟆。Elasticsearch會自動根據(jù)文檔信息,推算出字段的類型
  • 但是有時候會推算的不對舒裤,例如地理位置信息
  • 當類型如果設置不對時喳资,會導致一些功能無法正常運行,例如Range查詢
mapping查詢方式

mapping結果示例

類型自動識別

JSON類型 Elasticsearch類型
字符串 1. 匹配日期格式腾供,設置成Date
2. 匹配數(shù)字設置為float或者long仆邓,該選項默認關閉
3. 設置為Text,并且增加keyword子字段
布爾值 boolean
浮點數(shù) float
整數(shù) long
對象 Object
數(shù)組 由第一個非空數(shù)值的類型所決定
空值 忽略

能否更改Mapping的字段類型

  • 兩種情況
    • 新增加字段
      • Dynamic設置為true時伴鳖,一旦有新增字段的文檔寫入节值,Mapping也同時被更新
      • Dynamic設置為false時,Mapping不會被更新榜聂,新增字段的數(shù)據(jù)無法被索引搞疗,但是信息會出現(xiàn)在_source中
    • 對已有字段,一旦已經(jīng)有數(shù)據(jù)寫入须肆,就不再支持修改字段的定義
      • Lucene實現(xiàn)的倒排索引匿乃,一旦生成后,就不允許修改
    • 如果希望改變字段類型豌汇,必須Reindex API幢炸,重建索引
  • 原因
    • 如果修改了字段的數(shù)據(jù)類型,會導致已經(jīng)被索引的屬性無法被搜索
    • 但是如果是增加新的字段瘤礁,就不會有這樣的影響

控制Dynamic Mapings

"true" "false" "strict"
文檔可索引 YES YES NO
字段可索引 YES NO NO
Mapping被更新 YES NO NO
  • 當dynamic被設置成false時候阳懂,存在新增字段的數(shù)據(jù)寫入,該數(shù)據(jù)可以被索引
  • 當設置成Strict模式的時候,數(shù)據(jù)寫入直接報錯
控制mapping
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末岩调,一起剝皮案震驚了整個濱河市巷燥,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌号枕,老刑警劉巖缰揪,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異葱淳,居然都是意外死亡钝腺,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門赞厕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來艳狐,“玉大人,你說我怎么就攤上這事皿桑『聊浚” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵诲侮,是天一觀的道長镀虐。 經(jīng)常有香客問我,道長沟绪,這世上最難降的妖魔是什么刮便? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮绽慈,結果婚禮上恨旱,老公的妹妹穿的比我還像新娘。我一直安慰自己坝疼,他們只是感情好窖杀,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著裙士,像睡著了一般。 火紅的嫁衣襯著肌膚如雪管毙。 梳的紋絲不亂的頭發(fā)上腿椎,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機與錄音夭咬,去河邊找鬼啃炸。 笑死,一個胖子當著我的面吹牛卓舵,可吹牛的內容都是我干的南用。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼裹虫!你這毒婦竟也來了肿嘲?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤筑公,失蹤者是張志新(化名)和其女友劉穎雳窟,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體匣屡,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡封救,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了捣作。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片誉结。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖券躁,靈堂內的尸體忽然破棺而出惩坑,到底是詐尸還是另有隱情,我是刑警寧澤嘱朽,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布旭贬,位于F島的核電站,受9級特大地震影響搪泳,放射性物質發(fā)生泄漏稀轨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一岸军、第九天 我趴在偏房一處隱蔽的房頂上張望奋刽。 院中可真熱鬧,春花似錦艰赞、人聲如沸佣谐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽狭魂。三九已至,卻和暖如春党觅,著一層夾襖步出監(jiān)牢的瞬間雌澄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工杯瞻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留镐牺,地道東北人。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓魁莉,卻偏偏與公主長得像睬涧,于是被迫代替她去往敵國和親募胃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容