初学ES

把它当做数据库学习,比较容易理解

只创建索引(表)

1. 创建

(可以理解为创建数据库中的表)

PUT 索引名(表名)
{
"mappings": {
"properties": {
"age"(字段名):{
"type": "integer"(字段类型)
},
"title"(字段名):{
"type": "text"(字段类型)
}
}
}
}

2.创建好后查看索引结构

get 索引名

添加文档(数据)

如果索引不存在会先创建索引(表名)后创建(插入)文档(数据)

格式 :PUT 索引名(表名)/文档类型(类似于一个标识)/文档id(数据库表中的数据id)

PUT /db/_doc/1
{
"age":20,
"content":"内容:学习决定命运,细节决定成败",
"name":"张三的名字",
"title":"标题:学习决定命运,细节决定成"
}

执行后,相当于在db数据库创建了一个id为1的一条数据,可通过elasticsearch-head查看

查看文档(数据)

GET 索引名/文档类型/文档id

GET /db/_doc/1

version:版本号,从1开始记录,每次修改都会+1

_source:文档数据(可以理解为java返回的Model)

修改文档数据(数据update)

put方式修改

put /索引名/文档类型/文档Id
{
"age":19,(修改的新值)
"content":"1"(修改的新值)
}

注意:我原本数据中有name\title列,我执行的PUT操作没有写明name\title,执行后该文档就没有name\title字段了

post方式修改

POST /索引名/文档类型/文档Id/_update
{
"name":"张三的名字叫李四"
}

推荐使用这种方式,这种方式可以想改哪些字段的值就改哪些,不改的无需再次传入,不会消失,更方便

删除文档&索引

删除索引:delete 索引名

删除文档:delete 索引名/文档类型/文档id

各种条件查询

为了方便演示,首先先添加几条数据

1.简单搜索(根据某个字段查询)

根据上面GET DB得知,name字段type=keyword,content的字段type=text

模糊查找

text:会被IK粉刺及拆分

发现content中包含“内容”的全部查出来了

GET /db/_doc/_search?q=content:内容

精确查找

keyword:不会被IK分词器拆分

发现只有完全匹配才可以查出来

另外一种单字段查询方式

GET db/_doc/_search
{
"query":{
"match":{
"content":"学习"
}
}
}

2.复杂搜索

must与term区别

must是会进行模糊查询,term不会

例如一个content字段Type=text,使用must搜索关键字就可以搜出来,使用term就不行

多条件查询

must(And)

匹配年龄=20且内容包含“学习”的数据

GET db/_doc/_search
{
"query": {
"bool": {
"must": [
{
"match": {
"content":"学习 是的" 匹配满足“学习”或“是的”的数据,多条件使用空格隔开
}
},
{
"match": {
"age":20
}
}
]
}
}
}

should(or)

匹配content包含“王五”或者年龄为25的数据

GET db/_doc/_search
{
"query": {
"bool": {
"should": [
{
"match": {
"content":"王五"
}
},
{
"match": {
"age":25
}
}
]
}
}
}

must_not (!=)

匹配content不包含“王五”且年龄不为25的数据

GET db/_doc/_search
{
"query": {
"bool": {
"must_not": [
{
"match": {
"content":"王五"
}
},
{
"match": {
"age":25
}
}
]
}
}
}

区间查询

查询年龄≥20且≤25的数据

GET db/_doc/_search
{
"query": {
"bool": {
"filter":{
"range":{
"age":{
"gte":20,
"lte":25
}
}
}
}
}
}

gt 大于

gte 大于等于

lt 小于

lte 小于等于!

自定义字段返回

只返回age\name字段

GET db/_doc/_search
{
"query": {
"bool": {
"filter":{
"range":{
"age":{
"gte":20,
"lte":25
}
}
}
}
},
"_source": ["age","name"]
}

排序

按照年龄降序及分值降序排列,注意:如果没有查询条件,排序是没有_score分值的

GET db/_doc/_search
{
"query":{
"match":{
"content":"学习 是的"
}
},
"sort":[
{
"_score":{
"order":"desc"
},
"age":{
"order":"desc"
}
}
]
}

高亮

GET db/_doc/_search
{
"query":{
"match":{
"content":"学习"
}
},
"highlight":{
"pre_tags":"<mytag style='color:blue'>",为查找的关键字添加自定义的html代码前缀
"post_tags":"</mytag>",为查找的关键字添加自定义的html代码后缀
"fields":{
"content":{} 定义要高亮的字段
}
}
}

结果如下:

分页查询

GET db/_doc/_search
{
"query":{
"match":{
"content":"学习"
}
},
"from":0, 当前第几页
"size":2 每页显示几条数据
} GET db/_doc/_count 获得指定条件下总条数有多少
{
"query":{
"match":{
"content":"李四"
}
}
}

查看索引的相关信息

可以查出来每个索引使用的空间大小,记录数等信息

GET _cat/indices?v

ElasticSearch常用查询命令-kibana中使用的更多相关文章

  1. sql常用查询命令

    目录 SQL Server常用查询命令: 查看当前时间 查询所有数据库名 查询当前使用的数据库名 查询前几条数据 去重查询 字段换名 查询不等于 查询在两个值之间数据 查询条件或 模糊匹配查询 查询为 ...

  2. Eucalyptus常用查询命令

    前言: Elastic Utility Computing Architecture for Linking Your Programs To Useful Systems (Eucalyptus)  ...

  3. mysql常用查询命令

    转引自:https://www.cnblogs.com/widows/p/7137184.html 常用mysql命令 show variables like 'character_set_clien ...

  4. ElasticSearch 常用查询语句

    为了演示不同类型的 ElasticSearch 的查询,我们将使用书文档信息的集合(有以下字段:title(标题), authors(作者), summary(摘要), publish_date(发布 ...

  5. MySQL常用查询命令(连接查询&子查询)

    多张表联合起来查询即为连接查询,可分为: 内连接:等值连接.非等值连接.自连接 外连接:右外连接.左外连接 也就是先把多张表通过某种指定条件用join...on...语法连接起来,然后再进行where ...

  6. Oracle常用查询命令

    Oracle查询完整格式如下: Select  *  from XX where XX group by YY having XX order by YY Select count(*), XX fr ...

  7. elasticsearch 常用查询 + 删除索引 + 集群状态诊断

    1.多条件查询 curl -X POST \ http://10.0.0.42:9200/addressbook_user/_search \ -H 'cache-control: no-cache' ...

  8. MySQL常用查询命令(单表查询)

    查询语法如下: select... from... where... group by... (having)... order by...; 顺序是from (从指定表中) where (具体条件) ...

  9. Oracle 学习笔记 常用查询命令篇

    1.查询某个用户下有多少张表 有时候很有用  select count(*) from dba_tables t where t.owner='SCOTT';

随机推荐

  1. ApacheCN 大数据译文集(二) 20211206 更新

    Hadoop3 大数据分析 零.前言 一.Hadoop 简介 二.大数据分析概述 三.MapReduce 大数据处理 四.基于 Python 和 Hadoop 的科学计算和大数据分析 五.基于 R 和 ...

  2. CF1574F Occurrences

    考虑什么样的串是合法的. 直接考虑比较抽象,考虑具象化这个问题. 容易发现一个字符串的限制就相当于如果出现了其中一个字符 \(a_i = c\),那么 \(s\) 中 \(c\) 前 \(i - 1\ ...

  3. 封装jar问题java.lang.SecurityException: Invalid signature file digest for Manifest main attributes以及maven依赖重提解决

    1.jar包封装完成后,其他项目引用jar,启动时报错java.lang.SecurityException: Invalid signature file digest for Manifest m ...

  4. Ubuntu18 用新用户登录后退格键/方向键/制表键 乱码

    Ubuntu18新建用户后,用新用户登录,此时 退格键Backspace 变成了 ^H,且方向键.制表键.Del键等均失效 这样会造成很多的麻烦,解决方式有两种: 方式1:Ctrl + Backspa ...

  5. 拔掉网线后, 原本的 TCP 连接还存在吗?

    大家好,我是小林. 今天,聊一个有趣的问题:拔掉网线几秒,再插回去,原本的 TCP 连接还存在吗? 可能有的同学会说,网线都被拔掉了,那说明物理层被断开了,那在上层的传输层理应也会断开,所以原本的 T ...

  6. python 2048游戏控制器

    2048游戏控制器 1 evaluate 要用程序来处理就得对现实的问题进行量化,用数字来表示.在2048游戏中,我们的输入是一个棋局,让我们输出一个移动方向,这样我们需要对棋局进行量化,即我们要评估 ...

  7. Java基于ClassLoder/ InputStream 配合读取配置文件

    阅读java开源框架源码或者自己开发系统时配置文件是一个不能忽略的,在阅读开源代码的过程中尝尝困惑配置文件是如何被读取到内存中的.配置文件本身只是为系统运行提供参数的支持,个人阅读源码时重点不大可能放 ...

  8. 4.2 K8S超级完整安装配置

    前言: 采坑 k8s有3种安装方式,如下所示: minikube:这是一个k8s集群模拟器,只有一个节点的集群,只为了测试使用,master和node都在一台机器上 直接使用带有容器功能的云平台安装: ...

  9. Stroke

    // A simple blur shader, weighted on alphauniform sampler2D texture;void main(){    float radius = 0 ...

  10. OpenGL ES 3D空间中自定义显示空间

    在Android中,我们所熟知的是在ES管线中,其在图元装配时,会进行图元组装与图元分配,这样就回剪裁出来视景体中的物体.但是如果我想在3D场景中规定一个区域,凡是在这个区域中的物体就能显示出来,非这 ...