Elasticsearch搜索-索引mapping<2>

来源:https://mp.weixin.qq.com/s/3MLWKZ8akJk7HbZnKopmVA

动态映射

概念说明

DSL实例

创建索引

我们先创建一个新的索引,不指定mapping

PUT user_info_dynamic_mapping

查询mapping

查询该索引的mapping,可以看到mapping默认是空的

GET user_info_dynamic_mapping/_mappings


往索引写数据

我们往索引中写一条数据在看mappings

PUT user_info_dynamic_mapping/user_info_dynamic_mapping/1

{

   "id":1,

   "name":"张三",

   "birthdate":"1988-09-01"

}

我们看到7.0之后_doc(类型)被叫做终点名称。

查看mappings

再次查看该索引的mapping

GET user_info_dynamic_mapping/_mappings

可以看到加入数据后产生了mapping

再次写入数据

PUT user_info_dynamic_mapping/user_info_dynamic_mapping/2

{

   "id":2,

   "name":"李四",

   "birthdate":"1989-09-01",

   "sex":"男"

}

执行后mapping自动又创建了

注意:当我们想关闭改功能时可在创建mapping时指定   "dynamic":"strict",

日期检测

    当索引第一条数据入库时,ElasticSearch会自动猜测字段类型,如果该数据索引字段为日期型字符串,那么它被认为日期型,另外如果有新的字段添加第一条数据入索引也是该规则。比如:第一条数据格式为{"note":"2019-01-08"}那么改字段认定为日期型,但是实际我们想该字段为字符型,当再次添加{"note":"我是一条鱼"}这时改字段显然不是日期类型,此时会抛出异常下面我们通过设置date_detection为false来关闭日期检测

关闭日期检测

PUT  /user_info_dynamic_date

{

   "mappings": {

           "date_detection":false

   }

通过这种方式映射后面日期型也会映射为字符型,如果后面需要新增date类型字段,

元字段

    mapping元字段是mapping映射中描述文档本身的字段,大致可以分为文档属性元数据、文档元数据、索引元数据、路由元数据和自定义元数据。

分类元数据说明

文档属性元数据_index文档所属的索引

_id文档的id

_type文档所属类型

_uid由_type和_id字段组成

文档元数据_source文档的原生json字符串

_size整个_source字段的字节数大小

索引元数据_all自动组合所有的字段值

_field_names索引了每个字段的名称

路由元数据_parent指定文档之间父子关系,已过时

_routing将一个文档根据路由存储到指定分片上

自定义元数据_meta用于自定义元数据

_type

   在6.0.0中弃用。此doc的mapping type名, 自动被索引,可被查询,聚合,排序使用,或者脚本里访问 。

_id

doc的id,建索引时候传入 ,不被索引, 可通过_uid被查询,脚本里使用,不能参与聚合或排序。6.0之前的版本并不是这样的,因为它们支持多种类型,所以_type和_id被合并为一个名为_uid的复合主键。

_uid

   在6.0.0中弃用。现在,类型已被删除,文档由_id唯一标识,_uid字段仅作为查看_id字段以保持向后兼容。

_source

     _source字段包含在索引时间传递的原始JSON文档正文。_source字段本身没有编入索引(因此不可搜索),但它被存储,以便在执行获取请求(如get或search)时可以返回它。默认_source字段是开启的,也就是说,默认情况下存储文档的原始值。如果某个字段内容非常多(比如一篇小说),或者查询业务只需要对该字段进行搜索,返回文档id,然后通过其他途径查看文档原文,则不需要保留_source元字段。可以通过禁用_source元字段,在ElasticSearch 中只存储倒排索引,不保留字段原始值。

_size

    整个_source字段的字节数大小 。

_all

_all可能不再为在6.0+中创建的索引启用,请使用自定义字段和映射copy_to参数

_all字段是把其它字段拼接在一起的超级字段,所有的字段用空格分开,_all字段会被解析和索引,但是不存储。当你只想返回包含某个关键字的文档但是不明确地搜某个字段的时候就需要使用_all字段。按照官方文档的说法,_all元字段默认是禁用的,如果需要使用,可以通过"_all": {"enabled": true}开启,测试如下。PUT myindex { "mappings": { "mytype": { "_all": {"enabled": true}, "properties": { "title": { "type": "text" }, "content": { "type": "text" } } } } }但是创建失败,报错:”Enabling [_all] is disabled in 6.0. As a replacement, you can use [copy_to] on mapping fields to create your own catch all field.”看来在Elasticsearch 6. 0+中_all元字段是真的不能使用了。  

_field_names

_field_names字段索引文档中每个字段的名称,其中包含除null以外的任何值。存在查询使用此字段来查找对于特定字段具有或不具有任何非空值的文档。

_parent

   ES6.0+改为join的实现方式,使用join数据类型。

_routing

     使用以下公式将文档路由到索引中的特定分片:

shard_num = hash(_routing) % num_primary_shards,The default value used for _routing is the document’s _id. 

_routing的默认值是文档的_id。自定义路由模式可以通过指定每个文档的自定义路由值来实现。

文章来源:https://mp.weixin.qq.com/s/3MLWKZ8akJk7HbZnKopmVA

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353

推荐阅读更多精彩内容