Elasticsearch 创建以及修改索引结构
从问题出发,这篇内容可以解决以下几个问题:
一:如何开启关闭Es索引(数据库)?
二:如何创建索引(数据库)结构?
三:如何向已有索引(数据库)中添加类型(表)结构?
四:如何向已有类型(表)中添加新字段?
五:如何更改现有类型(表)中的字段类型?
六:如何删除索引(数据库)?
七:如何删除索引中某一个类型结构(同时删除数据以及数据结构)?
八:如何删除索引中某一类型结构的全部数据而不删除类型结构?
九:为什么同一索引下不同类型的结构如果字段名称相同会报错?
十:创建索引结构时注意事项以及问题?
一:如何开启关闭Es索引(数据库)?
关闭索引
POST /my_index/_close
开启索引
POST /my_index/_open
二:如何创建索引(数据库)结构?
PUT twitter
{
"mappings": {
"tweet": {
"properties": {
"message": {
"type": "text"
}
}
}
}
}
三:如何向已有索引(数据库)中添加类型(表)结构?
PUT twitter/_mapping/user
{
"properties": {
"name": {
"type": " keyword"
}
}
}
四:如何向已有类型(表)中添加新字段?
PUT twitter/_mapping/tweet
{
"properties": {
"user_name": {
"type": " keyword"
}
}
}
五:如何更改现有类型(表)中的字段类型?
无法更改;
六:如何删除索引(数据库)?
参考链接:https://www.cnblogs.com/Rawls/p/10110743.html
七:如何删除索引中某一个类型结构(同时删除数据以及数据结构)?
Elasticsearch不支持删除一个Type;
参考链接:https://blog.csdn.net/youzhouliu/article/details/79940729
八:如何删除索引中某一类型结构的全部数据而不删除类型结构?
POST /testindex/testtype/_delete_by_query?pretty
{
"query": {
"match_all": {
}
}
}
九:为什么同一索引下不同类型的结构如果字段名称相同会报错?
这个问题比较坑,什么意思呢?用我们使用关系型数据库的逻辑来说,就是同一个数据库里面,如果有两个不同的表,表里面都有name字段,
如果A表中name是varchar类型,B表中name是int类型,完了,这就没办法创建索引了。所以,我们在创建索引的时候要注意,为什么会有这样的问题呢?
难道是Es的bug?这个主要是因为Es使用的是lucene的框架,具体的原因大家可以参考官方文档 避免类型陷阱
十:创建索引结构时注意事项以及问题?
1: 明确字段存储类型,是int类型还是文本类型;
ES字段类型参考:https://blog.csdn.net/chengyuqiang/article/details/79048800
2: 文本类型情况下,一种是keyword,一种是text ;
二者的区别请参考:https://www.cnblogs.com/Rawls/p/10069670.html
3: 字段结构类型一旦定义之后,是无法修改的,就跟你在数据库中一样,以前是int类型,
是无法改成varchar类型的(在sqlserver 表中没有数据情况下可以修改)。
4: 如果需要修改结构类型,只能在在这个文档类型中新增一个字段了。
5: 同一个索引下面,字段名称尽量不要重复;
6: 字段名称如果有重复情况,一定要使用相同的字段类型,要么都是integer,要么都是text。
Elasticsearch 创建以及修改索引结构的更多相关文章
- SQL Server索引进阶:第十二级,创建,修改,删除
在第十级中我们看到了索引的内部结构,在第十一级中我们看到了平衡树结构潜在的负面影响:索引碎片.有了索引内部结构的知识,我们可以检查在执行数据定义语句和数据操作语句的时候,都发生了什么.在本级中我们介绍 ...
- SQLServer之修改索引
使用SSMS数据库管理工具修改索引 使用表设计器修改索引 表设计器可以修改任何类型的索引,修改索引的步骤相同,本示例为修改唯一非聚集索引. 1.连接数据库,选择数据库,选择数据表->右键点击表- ...
- SQLServer之创建辅助XML索引
创建辅助XML索引 使用 CREATE INDEX (Transact-SQL)Transact-SQL DDL 语句可创建辅助 XML 索引并且可指定所需的辅助 XML 索引的类型. 创建辅助 XM ...
- SQLServer之创建唯一聚集索引
创建唯一聚集索引典型实现 唯一索引可通过以下方式实现: PRIMARY KEY 或 UNIQUE 约束 在创建 PRIMARY KEY 约束时,如果不存在该表的聚集索引且未指定唯一非聚集索引,则将自动 ...
- SQLServer之创建非聚集索引
开始之前 典型实现 可以通过下列方法实现非聚集索引: UNIQUE 约束 在创建 UNIQUE 约束时,默认情况下将创建唯一非聚集索引,以便强制 UNIQUE 约束. 如果不存在该表的聚集索引,则可以 ...
- Elasticsearch创建索引和映射结构详解
前言 这篇文章详细介绍了如何创建索引和某个类型的映射. 下文中[address]指代elasticsearch服务器访问地址(http://localhost:9200). 1 创建索引 ...
- elasticsearch创建索引
1.通过elasticsearch-head 创建 (1)登录localhost:9100 (2)点击复合查询 (3)输入内容 (4)勾选易读,点击验证是否是JSON格式 (5)点击提交请求,返回 { ...
- Elasticsearch如何修改Mapping结构并实现业务零停机
Elasticsearch 版本:6.4.0 一.疑问 在项目中后期,如果想调整索引的 Mapping 结构,比如将 ik_smart 修改为 ik_max_word 或者 增加分片数量 等,但 El ...
- ElasticSearch 基本概念 and 索引操作 and 文档操作 and 批量操作 and 结构化查询 and 过滤查询
基本概念 索引: 类似于MySQL的表.索引的结构为全文搜索作准备,不存储原始的数据. 索引可以做分布式.每一个索引有一个或者多个分片 shard.每一个分片可以有多个副本 replica. 文档: ...
随机推荐
- ccflow表机构与运行机制(二次开发必看)
驰骋工作流引擎,工作流程管理系统,表结构与运行机制. ------------------------------------------------------- 前言: 1, ccflow 有自动 ...
- NET Core应用中使用缓存
NET Core应用中使用缓存 .NET Core针对缓存提供了很好的支持 ,我们不仅可以选择将数据缓存在应用进程自身的内存中,还可以采用分布式的形式将缓存数据存储在一个“中心数据库”中.对于分布式缓 ...
- Python进阶之函数式编程
函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计 ...
- 【笔记】两个根因分析方法:5WHY&10WHY
什么是问题根因分析 根本原因分析(root cause analysis):通过调查和分析问题哪里出错.为什么出错,寻求防止差错事故再次发生的必要措施,从而提高服务安全和质量. 根因分析目标 问题(发 ...
- java实现Windows记事本
给大家分享下我之前的作品: 源文件下载: 链接:https://pan.baidu.com/s/1N45VsS9aVgmvhvYjRLxBrA 提取码:b9fg 源码: JF_Notpad.jav ...
- 【公众号系列】两分钟学会SAP F1技巧
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[公众号系列]两分钟学会SAP F1技巧 写 ...
- Python爬虫之正则表达式(3)
# re.sub # 替换字符串中每一个匹配的子串后返回替换后的字符串 import re content = 'Extra strings Hello 1234567 World_This is a ...
- LeetCode算法题-Number Complement(Java实现-五种解法)
这是悦乐书的第240次更新,第253篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第107题(顺位题号是476).给定正整数,输出其补码数.补充策略是翻转其二进制表示的位 ...
- DRF 序列化器-Serializer (2)
作用 1. 序列化,序列化器会把模型对象转换成字典,经过response以后变成json字符串 2. 完成数据校验功能 3. 反序列化,把客户端发送过来的数据,经过request以后变成字典,序列化器 ...
- supervisor management kafka zookeeper
# cat kafka.ini [program:kafka] command=/usr/local/kafka/bin/kafka-server-start.sh /usr/local/kafka/ ...