elasticsearch如何使用?
ES和关系型数据库的数据对比
1、创建索引库
PUT/POST都可以,索引库名称必须全部小写,不能以下划线开头,也不能包含逗号
curl -XPUT 'http://192.168.136.131:9200/wangxiangyu_index/'
{"acknowledged":true}[root@localhost ~]#
在Marvel中查看:http://localhost:5601/app/marvel
2、创建索引
curl -XPOST http://192.168.136.131:9200/wangxiangyu_index/employee/1 -d '{
"first_name":"john",
"last_name":"smith",
"age":"25",
"about":"I love to go rock climbing"
}'
如果没有明确指定索引数据的ID,ES会自动生成一个随机的ID,需要使用POST参数
PUT和POST用法
PUT是幂等方法,POST不是。所以PUT用于更新、POST用于新增比较合适。
PUT,DELETE操作是幂等的。所谓幂等是指不管进行多少次操作,结果都一样。比如我用PUT修改一篇文章,然后在做同样的操作,每次操作后的结果并没有不同,DELETE也是一样。
POST操作不是幂等的,比如常见的POST重复加载问题:当我们多次发出同样的POST请求后,其结果是创建出了若干的资源。
还有一点需要注意的就是,创建操作可以使用POST,也可以使用PUT,区别在于POST是作用在一个集合资源之上的(/articles),而PUT操作是作用在一个具体资源之上的(/articles/123),比如说很多资源使用数据库自增主键作为标识信息,而创建的资源的标识信息到底是什么只能由服务端提供,这个时候就必须使用POST。
GET查询索引
查询所有
curl -XGET http://192.168.136.131:9200/wangxiangyu_index/employee/_search
按条件查询
curl -XGET http://192.168.136.131:9200/wangxiangyu_index/employee/_search?q=last_name:smith
curl -XGET http://192.168.136.131:9200/wangxiangyu_index/employee/1?pretty
在任意查询字符串中加pretty参数,es可以得到易于识别的json结果
curl后添加-i参数,可以得到反馈头文件
curl -i 'http://192.168.136.131:9200/wangxiangyu_index/employee/1?pretty'
检索文档中一部分数据
curl -XGET http://192.168.136.131:9200/wangxiangyu_index/employee/1?_source=age,about&pretty
只查询source部分的数据
curl -XGET http://192.168.136.131:9200/wangxiangyu_index/employee/1?_source
ES的更新
ES可以使用PUT或者POST对文档进行更新,如果指定ID的文档已经存在,则执行更新操作
注意:执行更新操作的时候
1、ES首先将旧的文档标记为删除状态
2、然后添加新的文档
3、旧的文档不会立即消失,但是也无法访问
4、ES会在你继续添加更多数据时在后台清理已经标记为删除状态的文档
局部更新
可以添加新字段或者更新已有的字段(必须使用POST)
curl -XPOST http://192.168.136.131:9200/wangxiangyu_index/employee/3/_update -d '{
"doc":{
"city":"beijing",
"car":"havel"
}
}'
ES的删除
curl -XDELETE http://192.168.136.131:9200/wangxiangyu_index/employee/4
curl -XDELETE 'http://192.168.136.131:9200/wangxiangyu_index/employee/_query?q=user:kimchy'
删除一个文档也不会立即生效,它只是被标记成已删除,ES将会在你之后添加更多索引的时候才会在后台进行删除内容的清理。
elasticsearch如何使用?的更多相关文章
- Elasticsearch之java的基本操作一
摘要 接触ElasticSearch已经有一段了.在这期间,遇到很多问题,但在最后自己的不断探索下解决了这些问题.看到网上或多或少的都有一些介绍ElasticSearch相关知识的文档,但个人觉得 ...
- Elasticsearch 5.0 中term 查询和match 查询的认识
Elasticsearch 5.0 关于term query和match query的认识 一.基本情况 前言:term query和match query牵扯的东西比较多,例如分词器.mapping ...
- 以bank account 数据为例,认识elasticsearch query 和 filter
Elasticsearch 查询语言(Query DSL)认识(一) 一.基本认识 查询子句的行为取决于 query context filter context 也就是执行的是查询(query)还是 ...
- Ubuntu 14.04中Elasticsearch集群配置
Ubuntu 14.04中Elasticsearch集群配置 前言:本文可用于elasticsearch集群搭建参考.细分为elasticsearch.yml配置和系统配置 达到的目的:各台机器配置成 ...
- ElasticSearch 5学习(10)——结构化查询(包括新特性)
之前我们所有的查询都属于命令行查询,但是不利于复杂的查询,而且一般在项目开发中不使用命令行查询方式,只有在调试测试时使用简单命令行查询,但是,如果想要善用搜索,我们必须使用请求体查询(request ...
- ElasticSearch 5学习(9)——映射和分析(string类型废弃)
在ElasticSearch中,存入文档的内容类似于传统数据每个字段一样,都会有一个指定的属性,为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成字符串值,Elasticsearc ...
- .net Elasticsearch 学习入门笔记
一. es安装相关1.elasticsearch安装 运行http://localhost:9200/2.head插件3.bigdesk插件安装(安装细节百度:windows elasticsear ...
- 自己写的数据交换工具——从Oracle到Elasticsearch
先说说需求的背景,由于业务数据都在Oracle数据库中,想要对它进行数据的分析会非常非常慢,用传统的数据仓库-->数据集市这种方式,集市层表会非常大,查询的时候如果再做一些group的操作,一个 ...
- 如何在Elasticsearch中安装中文分词器(IK+pinyin)
如果直接使用Elasticsearch的朋友在处理中文内容的搜索时,肯定会遇到很尴尬的问题--中文词语被分成了一个一个的汉字,当用Kibana作图的时候,按照term来分组,结果一个汉字被分成了一组. ...
- jar hell & elasticsearch ik 版本问题
想给es 安装一个ik 的插件, 我的es 是 2.4.0, 下载了一个版本是 1.9.5, [2016-10-09 16:56:26,248][INFO ][node ] [node-2] init ...
随机推荐
- Redis Cluster机器内存充爆处理
机器配置 系统:CentOS6.7 配置:4C8G 应用:Redis Cluster,实例化 现象 1.无法启动redis,启动后系统OOM,直接杀死 2.Redis: OOM command not ...
- Vue项目框架
Vue项目框架 基本组件的使用: new Vue({ el, //要绑定的DOM element data, //要绑定的资料 props, //可用来接收父原件资料的属性 template, //要 ...
- Java 策略模式(Strategy)
创建一个能够根据所传递的参数对象的不同而具有不同行为的方法 要执行的算法固定不变,封装到一个类(Context)中 策略就是传递进去的参数对象,它包含执行代码 策略接口 /** * 策略接口 */ p ...
- 【设计模式】—— 状态模式State
前言:[模式总览]——————————by xingoo 模式意图 允许一个对象在内部改变它的状态,并根据不同的状态有不同的操作行为. 例如,水在固体.液体.气体是三种状态,但是展现在我们面前的确实不 ...
- eclipse运行tomcat中发生异常重启后tomcat端口被占用
在任务管理器关闭javaw进程即可,一般此时会有两个以上javaw进程,关闭其中占用内存较少的那个 可用netstat -ano命令查看端口占用情况
- myeclipse运行错误
错误出现为: !MESSAGE Product com.genuitec.myeclipse.product.ide could not be found. 这是在我将其它电脑上的myeclipse拷 ...
- pgm9
这部分介绍 sampling 方法,书上也称为 particle-based method,这是因为每一个从分布中采集到的样本可以看成是一个 particle(instantiation of r.v ...
- POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离)
POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离) Description You have just moved from a ...
- 界面编程之QT的Socket通信20180730
/*******************************************************************************************/ 一.linu ...
- LeetCode 5回文数
判断一个整数是否是回文数.回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数. 示例 1: 输入: 121 输出: true 示例 2: 输入: -121 输出: false 解释: 从左向 ...