elasticSearch DLS基础语句

2023-11-02 09:59

本文主要是介绍elasticSearch DLS基础语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

elasticSearch数据库和mysql数据库的差异

mysql                               ======》                     elasticSearch  

数据库(database)            在es叫做                      (索引数据库) index    

表(table)                     在es叫做                      (类型) type   

行(row)                       在es叫做                      (文档) document   

列(column)                 在es叫做                      (字段)field 

表结构                            在es叫做                      (映射) _mapping    

操作之前,要先安装elasticsearch 数据库,再安装kibana,不知道怎么安装? 点我试试

创建数据库

mysql                 create databse studentinfo            

在es操作                PUT /studentinfo                                                                

创建表

在studentinfo(数据库)创建表,表的字段:id、name、age、height、remark、isHealth、类型如下

mysql           

                 

在es操作                            

                 

(这里我就不在mysql去创建表了)                      type:类型,可以是text、long、short、date、integer、object等

                                                                              index:是否索引,默认为true

                                                                              store:是否存储,默认为false

                                                                              analyzer:分词器,这里的ik_max_word即使用ik分词器

查看表字段

mysql            desc table                                                  

在es操作         GET studentinfo/_mapping/student                            

新增数据

mysql                 insert into table value ('','','')                      

在es操作              # 插入数据(不指定id,这里的id指的是es的_id,唯一

# 插入数据(不指定id)
POST studentinfo/student
{"id":"1","name":"张三","age":"15","height":"1.45","isHealth":true,"remark":"中学生"
}

批量新增

mysql                      INSERT INTO testTable (xx,xx) VALUES ('xx','xx'),('xx','xx'),('xx','xx')          

在es操作                 #批量新增(注意这里格式必须要格式化一下,kibana 快捷键ctrl + i ,不然会报错)

#批量新增
POST /studentinfo/student/_bulk
{"index":{}}
{"name":"李四","age":"28","height":"1.65","isHealth":true,"remark":"社会打工人"}
{"index":{}}
{"name":"王五","age":"37","height":"1.75","isHealth":true,"remark":"管理人员"}
{"index":{}}
{"name":"赵六","age":"24","height":"1.65","isHealth":true,"remark":"大学毕业时"}
{"index":{}}
{"name":"田七","age":"24","height":"1.65","isHealth":true,"remark":"良好四民"}

根据id查询

mysql                          select * from table where id = 1               

在es操作                     GET studentinfo/student/1      

根据id修改 (没有就新增)

mysql                     update table set xxx where id = 1             

在es操作                    #修改 (没有即新增)                                               

#修改 (没有即新增)
PUT studentinfo/student/1
{"name":"张三指定id修改,这里注意看 _version 乐观锁机制 加1 ","age":"251","height":"2.45","isHealth":false,"remark":"中学生指定id 修改了"
}

根据id删除

mysql                                 delete from table where id = 1                   

在es操作                             DELETE /studentinfo/student/1

根据条件查询再删除

mysql                                      delete from table where id in (select id from table where name like '%张%')                   

在es操作                                  #根据条件去删除

#根据条件去删除
POST /studentinfo/_delete_by_query
{"query":{"match": {"name": "张"}}
}

#多字段查询

POST /studentinfo/_search
{"query": {"multi_match": {"query": "四","fields": ["name","remark"]}}
}

#精确查询(一般用于查询数字,时间)

#精确查询(一般用于查询数字,时间)
POST studentinfo/_search
{"query": {"term": {"height": {"value": "1.65"}}}
}

#多个值  精确查询(一般用于查询数字,时间)

#多个值  精确查询(一般用于查询数字,时间)
POST studentinfo/_search
{"query": {"terms": {"height": ["1.75","1.65"]}}
}

#查询指定字段

mysql                                   select id,name,height,xxx from table                       

在es操作                               #查询指定字段

#查询指定字段
POST studentinfo/_search
{"_source": ["name","remark","height"], "query": {"terms": {"height": ["1.75","1.65"]}}
}

#范围查询

mysql                               select * from table where age>=25 and age <30                       

在es操作                           #范围查询

#范围查询
POST studentinfo/_search
{"query": {"range": {"age": {"gte": 25,"lt": 30}}}
}

#排序 多字段

#排序 多字段
POST studentinfo/_search
{"query": {"match_all": {}},"sort": [{"age": {"order": "asc"}},{"_score": {"order": "asc"}}]
}

#高亮

#高亮
POST studentinfo/_search
{"query": {"match": {"name": "四"}},"highlight": {"pre_tags": "<b color='red'","post_tags": "<b>","fields": {"name": {}}}
}

#分页  分页公式:int start = {pageNum-1}*size

mysql                           select * from table limit 2,2                       

在es操作                      #分页  分页公式:int start = {pageNum-1}*size

#分页  分页公式:int start = {pageNum-1}*size
POST studentinfo/_search
{"query": {"match_all": {}},"from": 2,"size": 2
}

#地理查询

mysql     select * from xx where  a between 10.2  and  30.3

在es操作        

公式1: (不常用  根据两个点画出矩形,查询这个矩形内的所有东西)
GET /indexName/_search
{"query":{"geo_bounding_box":{"FIELD":{"top_left":{"lat":22.2,"lon":33.3},"bottom_right":{"lat":44.4,"lon":55.5},}}}
}公式2: (常用  以自己为中心,画出5km的半径,然后画一个圆 搜索圆里面的内容 )
GET /indexName/_search
{"query":{"geo_distance":{"FIELD":{"distance":"5km""FIELD":"11.1,22.2"}}}
}

 如果小伙伴们有什么疑问,欢迎下面评论。欢迎指正。如还有什么不懂的加我 QQ:517861659

如果没有及时回复,可以点我先问问AI机器人https://chatgpt.byabstudio.com/login?code=202307011314  

这篇关于elasticSearch DLS基础语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329838

相关文章

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

Mybatis Plus JSqlParser解析sql语句及JSqlParser安装步骤

《MybatisPlusJSqlParser解析sql语句及JSqlParser安装步骤》JSqlParser是一个用于解析SQL语句的Java库,它可以将SQL语句解析为一个Java对象树,允许... 目录【一】jsqlParser 是什么【二】JSqlParser 的安装步骤【三】使用场景【1】sql语

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

sql语句字段截取方法

《sql语句字段截取方法》在MySQL中,使用SUBSTRING函数可以实现字段截取,下面给大家分享sql语句字段截取方法,感兴趣的朋友一起看看吧... 目录sql语句字段截取sql 截取表中指定字段sql语句字段截取1、在mysql中,使用SUBSTRING函数可以实现字段截取。例如,要截取一个字符串字

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门