ElasticSearch学习笔记

环境配置

  • windows环境下安装es,从官网下载windows版本的安装包,解压缩即可。
  • 安装head插件教程
  • 需要注意的是,在安装过程中head插件的过程中,需要用到node环境,如果网络没有翻墙,使用node自带的源进行更新或安装会出现警告,某些node的依赖版本的问题,此时需要安装node的淘宝源,使用cnpm命令进行操作即可。

ES操作

  • 当前使用的 ES版本是7.2,这个版本的ES已经不支持自定义类型了,一个索引下只能有一个类型,默认名称是_doc。这里是使用Postman进行操作的:
添加索引
// 老版本的添加索引
PUT localhost:9200/people
{
    "settings": {
        "number_of_shards": 3,
        "number_of_replicas": 1
    },
    "mappings": {
        "man": {
            "properties": {
                "name": {
                    "type": "text"
                }
            }
        }
    }
}

// 新版本的添加索引
PUT localhost:9200/people
{
    "settings": {
        "number_of_shards": 3,
        "number_of_replicas": 1
    },
    "mappings": {
        "properties": {
            "name": {
                "type": "text"
            }
        }
    }
}
删除索引
DELETE localhost:9200/people
索引文档
// 指定id索引文档
PUT localhost:9200/people/_doc/1
{
	"name":"111"
}

// 不指定id索引文档,ES将会自动为文档生成id,但是这里只支持了POST请求
POST localhost:9200/people/_doc
{
	"name":"111"
}
  • 索引的两个文档:
    索引的文档
修改文档
// 指定修改文档的某个属性,也可以使用索引新的文档的方式对文档进行全量替换
POST localhost:9200/people/_update/1
{
    "doc": {
        "name": "Tommy"
    }
}

// 使用脚本语言对文档进行修改,两种写法
POST localhost:9200/people/_update/1

{
    "script": "ctx._source.name = 'John'" // 内置的脚本语言为painless
}

{
    "script": {
        "lang": "painless", // 指定脚本语言
        "inline": "ctx._source.name = 'Lucky'" // 执行的脚本语言
    }
}
删除文档
DELETE localhost:9200/people/_doc/1
文档查询
  1. 模糊匹配: match
  2. 短语模糊匹配: match_phrase
  3. 多字段模糊匹配: multi_match
  4. 字符串查询: query_string
  5. 指定字段查询: term
  6. 范围查询: range
  7. filter查询需要结合bool条件使用(缓存),且效率比上述的query查询效率高

相关资料

https://elasticsearch.cn/article/337
官方文档:https://www.elastic.co/guide/en/elasticsearch/reference/7.2/removal-of-types.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值