欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ElasticSearch 動(dòng)態(tài)映射實(shí)戰(zhàn)詳解

 更新時(shí)間:2023年01月31日 14:32:49   作者:程序員皮卡秋  
這篇文章主要為大家介紹了ElasticSearch 動(dòng)態(tài)映射實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

什么是動(dòng)態(tài)映射

通俗的講,就是文檔中的字段類型可以由ES動(dòng)態(tài)識(shí)別,無(wú)需在創(chuàng)建索引的時(shí)候規(guī)定字段的類型。

比如在項(xiàng)目中,如果不確定字段數(shù)據(jù)類型的情況下,可以使用動(dòng)態(tài)映射,ES可以利用動(dòng)態(tài)映射來(lái)決定該字段的類型,并自動(dòng)把該字段添加到映射中。

在使用的時(shí)候要結(jié)合實(shí)際業(yè)務(wù)來(lái)考慮,如果將 ES 當(dāng)作主要的數(shù)據(jù)存儲(chǔ)使用,并且希望出現(xiàn)未知字段時(shí)拋出異常,那么開啟動(dòng)態(tài) mapping 并不適用。

***在不確定索引類型字段時(shí),可以先創(chuàng)建臨時(shí)索引,然后存儲(chǔ)數(shù)據(jù),查詢映射。再刪除臨時(shí)索引。這樣就得到數(shù)據(jù)的基本映射了,可以在其上做精細(xì)化修改。 ***

映射規(guī)則

  • null 沒有字段被添加
  • true or false boolean 類型
  • 浮點(diǎn)類型數(shù)字 float 類型
  • 數(shù)字 long 類型
  • JSON 對(duì)象 object 類型
  • 數(shù)組 由數(shù)組中第一個(gè)非空值決定
  • string 有可能是 date 類型(若開啟日期檢測(cè))、double 或 long 類型、text 類型、keyword 類型

在 mapping 中可以通過 dynamic 設(shè)置來(lái)控制是否自動(dòng)新增字段,接受以下參數(shù):

  • true:默認(rèn)值為 true,自動(dòng)添加字段。
  • false:忽略新的字段。
  • strict:嚴(yán)格模式,發(fā)現(xiàn)新的字段拋出異常。

日期規(guī)則

es中當(dāng)字符串的格式為:yyyy/MM/dd HH:mm:ss Z||yyyy/MM/dd Z時(shí),es動(dòng)態(tài)模板會(huì)自動(dòng)認(rèn)為該字符串為日志類型

  • 可以通過date_detection來(lái)關(guān)閉日期模板匹配
  • 可以通過dynamic_date_formats來(lái)指定日期字符匹配模板
PUT my_index
{
"mappings": {
  "dynamic_date_formats": ["MM/dd/yyyy"]
}
}

數(shù)字檢測(cè)

動(dòng)態(tài)映射有時(shí)會(huì)將數(shù)字映射為字符串類型,可以通過開啟數(shù)字檢測(cè)來(lái)解決該問題

PUT my_index
{
"mappings": {
  "numeric_detection": true
}
}

動(dòng)態(tài)映射模板

定義動(dòng)態(tài)映射模板,來(lái)格式化動(dòng)態(tài)映射的規(guī)則,動(dòng)態(tài)映射模板包含以下關(guān)鍵字:

  • match_mapping_type:用來(lái)匹配當(dāng)前映射的字段類型??梢岳斫鉃?,當(dāng)字段類型為match_mapping_type時(shí)
  • match、unmatch 、match_pattern:用來(lái)匹配當(dāng)前映射字段的名稱??梢岳斫鉃椋?dāng)字段名稱匹配match、match_pattern時(shí),當(dāng)字段名稱不匹配unmatch時(shí)
  • path_match、path_unmatch:用來(lái)匹配當(dāng)前映射字段的路徑,通常用來(lái)匹配嵌套字段??梢岳斫鉃?,當(dāng)字段路徑為path_match時(shí),當(dāng)字段路徑不匹配path_unmatch時(shí)
  • {name}, {dynamic_type} :用來(lái)進(jìn)行占位符匹配,具體怎么用,都可以,但是最終映射的值為name或動(dòng)態(tài)類型 當(dāng)然也可以直接強(qiáng)制指定類型和屬性

下面看一些示例:

match_mapping_type

dynamic_templates是動(dòng)態(tài)模板名稱,什么字段都可以。integersstrings時(shí)動(dòng)態(tài)模板項(xiàng)名稱

PUT my_index
{
"mappings": {
 "dynamic_templates": [
   {
     "integers": {
       "match_mapping_type": "long",
       "mapping": {
         "type": "integer"
       }
     }
   },
   {
     "strings": {
       "match_mapping_type": "string",
       "mapping": {
         "type": "text",
         "fields": {
           "raw": {
             "type":  "keyword",
             "ignore_above": 256
           }
         }
       }
     }
   }
 ]
}
}

match、unmatch

PUT my_index
{
"mappings": {
 "dynamic_templates": [
   {
     "longs_as_strings": {
       "match":   "long_*",
       "unmatch": "*_text",
       "mapping": {
         "type": "long"
       }
     }
   }
 ]
}
}

match_pattern

{
"mappings": {
 "dynamic_templates": [
   {
     "longs_as_strings": {
       "match_pattern": "regex",  
       "match": "^profit_\d+$",
       "unmatch": "*_text",
       "mapping": {
         "type": "long"
       }
     }
   }
 ]
}
}

path_match、path_unmatch

{ 
    "mappings": { 
        "dynamic_templates": [ 
            {
                "full_name": {
                    "path_match": "name.*",
                    "path_unmatch": "*.middle",
                    "mapping": {
                        "type": "text",
                        "copy_to": "full_name"
                    }
                }
            } 
        ] 
    } 
}

{name}、{dynamic_type}

{
  "mappings": {
    "dynamic_templates": [
      {
        "named_analyzers": {
          "match_mapping_type": "string",
          "match": "*",
          "mapping": {
            "type": "text",
            "analyzer": "{name}"
          }
        }
      },
      {
        "no_doc_values": {
          "match_mapping_type":"*",
          "mapping": {
            "type": "{dynamic_type}",
            "doc_values": false
          }
        }
      }
    ]
  }
}

直接指定類型

{
  "mappings": {
    "dynamic_templates": [
      {
        "strings_as_keywords": {
          "match_mapping_type": "string",
          "mapping": {
            "type": "keyword"
          }
        }
      }
    ]
  }
}

索引模板

索引模板的作用是提前創(chuàng)建好模板,后續(xù)索引的創(chuàng)建會(huì)根據(jù)匹配規(guī)則,自動(dòng)生成該索引的配置

  • 模板只在索引創(chuàng)建時(shí)起作用,修改模板不會(huì)影響已創(chuàng)建的索引。
  • 可以設(shè)置多個(gè)索引模板,這些設(shè)置會(huì)被 merge 在一起。
  • 可以設(shè)置 order 的數(shù)值,控制 merge 的過程。

當(dāng)一個(gè)索引被創(chuàng)建時(shí),如果符合多個(gè)模板,那么模板之間merge符合以下規(guī)則:

  • order 值高的模板會(huì)覆蓋 order 值低的模板。
  • 相同字段會(huì)覆蓋
  • 不同字段會(huì)疊加

感興趣的同學(xué),可以自行去查詢相關(guān)文檔,這個(gè)不是很常用

結(jié)束語(yǔ)

本節(jié)主要講了ES中的動(dòng)態(tài)mapping概念以及它的相關(guān)屬性。下節(jié)給大家講ES中文檔相關(guān)的API操作。

以上就是ElasticSearch 動(dòng)態(tài)映射實(shí)戰(zhàn)詳解的詳細(xì)內(nèi)容,更多關(guān)于ElasticSearch 動(dòng)態(tài)映射的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • RocketMQ設(shè)計(jì)之同步刷盤

    RocketMQ設(shè)計(jì)之同步刷盤

    這篇文章主要介紹了RocketMQ設(shè)計(jì)之同步刷盤,文章主要通過CommitLog的handleDiskFlush方法展開全文內(nèi)容,實(shí)現(xiàn)同步刷盤,下面文章詳細(xì)介紹,需要的小伙伴可以參考一下
    2022-03-03
  • MybatisPlus的LambdaQueryWrapper用法詳解

    MybatisPlus的LambdaQueryWrapper用法詳解

    LambdaQueryWrapper<Tag>?是 MyBatis-Plus 框架中的一個(gè)功能強(qiáng)大的查詢構(gòu)造器,它用于構(gòu)建 SQL 查詢條件,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-10-10
  • 用Java制作用戶登錄界面超詳細(xì)圖文教程

    用Java制作用戶登錄界面超詳細(xì)圖文教程

    很多人學(xué)習(xí)Java的第一個(gè)任務(wù)是使用Java設(shè)計(jì)客戶端登錄界面中,希望我的學(xué)習(xí)方法與總結(jié)能幫助到需要的朋友,這篇文章主要給大家介紹了關(guān)于用Java制作用戶登錄界面的相關(guān)資料,需要的朋友可以參考下
    2024-06-06
  • SpringBoot 如何實(shí)時(shí)刷新靜態(tài)文件

    SpringBoot 如何實(shí)時(shí)刷新靜態(tài)文件

    這篇文章主要介紹了SpringBoot如何實(shí)時(shí)刷新靜態(tài)文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java int與integer的對(duì)比區(qū)別

    Java int與integer的對(duì)比區(qū)別

    這篇文章主要介紹了Java int與integer的對(duì)比區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • idea 實(shí)現(xiàn)縱列選擇和大小寫轉(zhuǎn)換操作

    idea 實(shí)現(xiàn)縱列選擇和大小寫轉(zhuǎn)換操作

    這篇文章主要介紹了idea 實(shí)現(xiàn)縱列選擇和大小寫轉(zhuǎn)換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2021-02-02
  • Java正則表達(dá)式判斷字符串中是否包含中文示例

    Java正則表達(dá)式判斷字符串中是否包含中文示例

    之前一個(gè)朋友問我,如何判斷字符串中是否包含中文,其實(shí)解決的方法很簡(jiǎn)單,但覺著有必要寫出給不知道的朋友們以參考,所以下面這篇文章主要介紹了利用Java正則表達(dá)式判斷字符串中是否包含中文的方法,需要的朋友可以參考。
    2017-03-03
  • Java Web中常用的分頁(yè)組件(Java端實(shí)現(xiàn))

    Java Web中常用的分頁(yè)組件(Java端實(shí)現(xiàn))

    本文通過使用場(chǎng)景分析給大家介紹了Java Web中常用的分頁(yè)組件(Java端實(shí)現(xiàn)),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-05-05
  • 在Java中使用redisTemplate操作緩存的方法示例

    在Java中使用redisTemplate操作緩存的方法示例

    這篇文章主要介紹了在Java中使用redisTemplate操作緩存的方法示例,在Redis中可以存儲(chǔ)String、List、Set、Hash、Zset。感興趣的可以了解一下
    2019-01-01
  • 詳解java nio中的select和channel

    詳解java nio中的select和channel

    這篇文章主要介紹了java nio中的select和channel
    2019-05-05

最新評(píng)論