es修改字段类型(es修改索引字段属性)

本篇文章给大家谈谈es修改字段类型,以及es修改索引字段属性对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

es修改索引字段类型

由于ElasticSearch没有像薯茄吵mysql一样可以直接字段数据类型的方法,因此需要通过创建中间索引:data_index_1,备份数据到中间索引:data_index_1,然后删除原索引: data_index,重新创建正确数据类型索引:data_index,再把中间索引:data_index_1的数据备份到新创建索引:data_index。数侍语句通过kibana的 dev_tools/console 执行。

PUT demo_metric_1/

POST demo_metric_1/type/_mapping

{

"type": {

"properties": {

"log_time_date": {

"type": "date",

"format": "epoch_millis"

},

.....

}

}

}

POST _reindex

{

"source": {

"index": "demo_metric"

},

"dest": {

"index": "demo_metric_1"

}

}

GET /demo_metric/type/_search

GET /demo_metric_1/type/_search

DELETE demo_metric

PUT demo_metric/

POST demo_metric/type/_mapping

{

"type": {

"properties": {

"log_time_date": {

"type": "date",

"format": "epoch_millis"

},

.....

}

}

}

POST _reindex

{

"source"纳纤: {

"index": "demo_metric_1"

},

"dest": {

"index": "demo_metric"

}

}

DELETE demo_metric_1

原文链接:

ES 源码分析之数据类型转换

代码具体入口 org.elasticsearch.index.shard.IndexShard#prepareIndex

代码位置: org.elasticsearch.index.mapper.MetadataFieldMapper#preParse

下面只贴出 _id 的处理

ES 在转换 nested 结构的时候,比较有意思。

每个字段的填充入口在:枯樱 org.elasticsearch.index.mapper.DocumentParser#innerParseObject

这里是一个递归调用的操作。没缓丛比较绕。

下面贴出来 _version 的处理

代码的入口: org.elasticsearch.index.mapper.VersionFieldMapper#postParse ,可以看看具哪耐体的实现。

Elasticsearch 字段类型

在学习 ES 文档相关操作之前,我们先学习 ES 中常用的字段类型。

当一个字段的内容需要被全文检索时,可以使用 text 类型,支持长内容的存储,比如检索文章内容、商品信息等。该类型的字段内容在保存时会被分词器分析,并且拆分成多个词项, 然后根据拆分后的词项生成对应的索引,根据关键字检索时可能会将关键字分词,用分好的词从之前生成的索引中去匹配,进而找到对应的文档。对于 text 类型的字段你可能无法通过指定文本精确的检索到。另外需要注意的是, text 类型的字段不能直接用于排序、聚合操作。这种类型的字符串也称做 analyzed 字符串。

keyword 类型适用于结构化的字段,比如手机号、商品id、用户id等,默认最大长度为256。 keyword 类型的字段内容不会被分词器分析、拆分,而是根据原始文本直接生成倒排索引,所以 keyword 类型的字段可以直接通过原始文本精确的检索到。 keyword 类型的字段可用于过滤、排序、聚合操作。这种字符串称做 not-analyzed 字符串。

ES 中的 date 类型默认支持如下两种格式:

如果我们要存储类似 2020-12-01 20:10:15 这种格式的日期就会有问题,我们可以在创建索引时指定字段为 date 类型以及可以匹配的日期格式:

需要注意的是,如果不主动指定字段类型为 date ,ES 默认使用 text 类型去保存日期的值。

boolean 类型就简单了,有 true 、 false 两个值。

一般情况下,如果可以满足需求,则优先使用范围小的类型,来提高效率。

其实在 ES 中并没有数组类型,但我们却可以按数组格式来存储数据,因为 ES 中默认每个字段可以包含多个值,同时要求多个值得类型必须一致。例如可以按照如下方式指定一个字段的值为数组:

这个其实没什么特别的,由于 ES 中以 JSON 格式存储数据,所以一个 JSON 对象中的某个字段值可以是另一个 JSON 对象。

例如信核我们可以创建索引时定义一个日期范围的字段类型:

添加文档时可以这样指定字段的值:

最后我们通过一个完整的例子梳理一下这些字段类型,首先创建 blog 索引,并指定相关字段的类型:

然后添加一条文档数据:

上边我们只指定了 publishDate 和 reader_age_range 字段的类型,其它的并未指定。其实在添加文档时,ES 也会根滑闷掘据字段的值动态的推断出它的类型,即动态映射,但这样可能出现推断不符合预期的问题,例如前罩高边说过的日期类型,所以你可以根据实际情况选择是否主动指定字段的类型。

再使用如下请求查看一下文档字段的 mapping 信息:

结果如下:

由于我们未指定 title 字段的类型, ES 自动将其映射成了 text 类型,同时还添加了一个类型为 keyword 的字段:

ES 中常用的字段类型就介绍到这里了。其中 text 和 keyword 可能理解起来比较抽象,但也是重点,后边结合具体的例子就好理解了,分词相关的内容后边也会专门介绍。

[img]

Elasticsearch数据增删改

    本文介绍 ElasticSearch 增加、删除、修改的使用示例。通过Restful 接口和 Postman实现.ElasticSearch 版本为6.3.2。

关于索引的创建请参考:

关于es的安装请参考:

我先创建一个叫local_mst_student_idx_1的索引,通过hand插件观察他的count条数为0.(详细见下图)

单条新增(指定_id):

URL:http://服务ip:端口/索引index/type/_id

单条新增(不指定_id):

URL:http://服务ip:端口/索引index/type

es会自动生成一个唯一的_id

批量悉槐新增:

关于批量新增我们需要创建一个.json的文件,里面构建json数据。(如下图)

通过postman请求:

注意:通过post请求body这时候需要选择bonary,然后选择我们刚刚创建的.json文件即可。(详细如下图)

点击执行我们可能会遇到下面这种情况,那是因为body的类型是text类型的,它不支持,我们点击下拉框改成JSON选项就ok了。

下面我展示一下执行批量新增的效果图:

上面明显的返回了我们新增的数据信息。

(注:批量新增可以在URL中指定index和type也可已睁租友在.json文件中指定;我上面是使用URL指定index和type的,官网文档案例是在.json文档中指定,大家可以参考一下。)

关于批量新增有啥疑问的可以参考官方文档:

执行完后我们通过hand插件观察Elasticsearch数据情况:(如下图)

很清晰的看出我们新增的数据已经全部到ES里面。

单个删除:

URL:http://服务ip:端口号/索引index/type/_id   (_id:指定删除)

单个删除比较简单:(如下图)

查询式删除:

通过条件查询删除某些符合条件的数据;我们测试把张三和王五删除掉。

关于批量删除有什么疑问的可以参考官方文档:

执行成功后观察数据是否被删除:

ES修改操作有一种特殊;假如我们使用下图这种请求

通过观察我指定_id为4的数据进行修改,他只修改了我传参的stu_name字段,并把其他字段全部改为空了。

其实是这样的:

    当我们发送该请求后,如果不存在_id=4的文档数据,索引中将新建一个文档_id=4,如果索引中在之前已经存在_id=4的文档数据,新文档数据将覆盖历史文档数据。如果我们存入的文档id和已存在的文档id都不相同则不会影响。索引文档时,_id部型搜分是可选的,我们上面也有案例,如果未指定,es将生成一个随机_id,然后用它来创建新文档。当然我可能不想要这种效果。别急下面我来讲解另外一种修改方式。

修改数据2:

这里我们发现和上面的请求有哪些不同,我们发现下面图片的 URL 的末尾多了一个_update请求命令.

这种更新其实也不是在原文档进行就地更新。es无论何时进行更新他都会删除旧文档,索引一个新文档来立刻替换它。当然es还提供了多条件的修改。我们可以参考官方文档去挖掘在此我就不详细的讲解了。

关于es多条件的修改可以参考官方文档:

关于增删改我们就讲到这,新的探索我会再第一时间给大家分享。

如何对es系统中的字段进行修改

静态方法不能访问非静态成员(包括静态方法和静态变量),但非静态方法可以静态成员和非静态成员。方法或变量加上static声明就被定义为静态成埋手饥员。静态成员属于类所有,被类的所有对象共享,它在程序预编译期间就能确定。非静态成员属于对象所有,而对象需要在程序运行期间分配空间。故在预编译期间就能确定的静态成员不能访问需要在程序运行时才能薯行确定的非静态成员。针对你的问题,main是静态方法,它只能访问静态成员,所以它弯返可以访问static的b,不能访问没有static声明的rand,解决方法就是在成员声明前加static关键字,表明该成员是静态成员。

关于es修改字段类型和es修改索引字段属性的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

标签列表