ElasticSearch常用查询命令-kibana中使用
初学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中使用的更多相关文章
- sql常用查询命令
目录 SQL Server常用查询命令: 查看当前时间 查询所有数据库名 查询当前使用的数据库名 查询前几条数据 去重查询 字段换名 查询不等于 查询在两个值之间数据 查询条件或 模糊匹配查询 查询为 ...
- Eucalyptus常用查询命令
前言: Elastic Utility Computing Architecture for Linking Your Programs To Useful Systems (Eucalyptus) ...
- mysql常用查询命令
转引自:https://www.cnblogs.com/widows/p/7137184.html 常用mysql命令 show variables like 'character_set_clien ...
- ElasticSearch 常用查询语句
为了演示不同类型的 ElasticSearch 的查询,我们将使用书文档信息的集合(有以下字段:title(标题), authors(作者), summary(摘要), publish_date(发布 ...
- MySQL常用查询命令(连接查询&子查询)
多张表联合起来查询即为连接查询,可分为: 内连接:等值连接.非等值连接.自连接 外连接:右外连接.左外连接 也就是先把多张表通过某种指定条件用join...on...语法连接起来,然后再进行where ...
- Oracle常用查询命令
Oracle查询完整格式如下: Select * from XX where XX group by YY having XX order by YY Select count(*), XX fr ...
- elasticsearch 常用查询 + 删除索引 + 集群状态诊断
1.多条件查询 curl -X POST \ http://10.0.0.42:9200/addressbook_user/_search \ -H 'cache-control: no-cache' ...
- MySQL常用查询命令(单表查询)
查询语法如下: select... from... where... group by... (having)... order by...; 顺序是from (从指定表中) where (具体条件) ...
- Oracle 学习笔记 常用查询命令篇
1.查询某个用户下有多少张表 有时候很有用 select count(*) from dba_tables t where t.owner='SCOTT';
随机推荐
- 学习MyBatis必知必会(6)~Mapper基础的拓展
一.typeAlias 类型别名[自定义别名.系统自带别名] 1.类型别名:为 Java 类型设置一个缩写名字. 它仅用于 XML 配置,意在降低冗余的全限定类名书写 2.配置自定义别名: (1)方式 ...
- ApacheCN 网络安全译文集 20211025 更新
Android 渗透测试学习手册 中文版 第一章 Android 安全入门 第二章 准备实验环境 第三章 Android 应用的逆向和审计 第四章 对 Android 设备进行流量分析 第五章 And ...
- C++/WinUI 3 技术笔记(一)
微软在 Windows 10 Version 1809 上正式发布了新的 UI 框架,命名为 WinUI 3. 这已经是微软发布的第不知道多少个 UI 框架了,但是微软宣称它将支持原生 C++ 和 W ...
- C语言system函数
我们今天来看看在windows操作系统下system () 函数详解(主要是在C语言中的应用) 注意:在windows下的system函数中命令可以不区别大小写! 函数名: system 功 能: 发 ...
- indexOf() 和 lastIndexOf()
一,定义和用法 indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置. lastIndexOf() 方法可返回一个指定的字符串值最后出现的位置,在一个字符串中的指定位置从后向前搜索 ...
- Solution -「Gym 102759C」Economic One-way Roads
\(\mathcal{Description}\) Link. 给定一个含 \(n\) 个点 \(m\) 条边的简单无向图,每条边的两种定向方法各有权值,求使得图强连通且定向权值和最小的方法. ...
- Sunlogin RCE漏洞分析和使用
介绍 前两天网上曝出了关于向日葵远控工具(Sunlogin)Windows个人版的RCE漏洞POC.因为利用简单并且网上出现了公开的自动化扫描脚本,所以测试的人很多,也出现了一些真实攻击.漏洞的问 ...
- macbook安装scala、hadoop、saprk环境
一.scala安装 1. 安装jdk 有mac专用的jdk安装包,这里下载安装jdk1.8 2. 安装scala 2.1下载scala 2.2解压到指定目录 tar -zxvf /Users/lode ...
- 【摸鱼神器】基于SSM风格的Java源代码生成器 单表生成 一对一、一对多、多对多连接查询生成
一.序言 UCode Cms 是一款Maven版的Java源代码生成器,是快速构建项目的利器.代码生成器模块属于可拆卸模块,即按需引入.代码生成器生成SSM(Spring.SpringBoot.Myb ...
- 疑难杂症:运用 transform 导致文本模糊的现象探究
在我们的页面中,经常会出现这样的问题,一块区域内的文本或者边框,在展示的时候,变得特别的模糊,如下(数据经过脱敏处理): 正常而言,应该是这样的: emmm,可能大图不是很明显,我们取一细节对比,就非 ...