zoukankan      html  css  js  c++  java
  • elasticsearch 入门

    概念:

    我们的应用经常需要添加检索功能,开源的 ElasticSearch 是目前全文搜索引擎的首选。他可以快速的存储、搜索和分析海量数据。Spring Boot通过整合Spring Data ElasticSearch为我们提供了非常便捷的检索功能支持;

    Elasticsearch是一个分布式搜索服务,提供Restful API,底层基于Lucene,采用多shard(分片)的方式保证数据安全,并且提供自动resharding的功能,github等大型的站点也是采用了ElasticSearch作为其搜索服务。

    • 以 员工文档 的形式存储为例:一个文档代表一个员工数据。存储数据到 ElasticSearch 的行为叫做 索引 ,但在索引一个文档之前,需要确定将文档存储在哪里。

    • 一个 ElasticSearch 集群可以 包含多个 索引 ,相应的每个索引可以包含多个 类型 。 这些不同的类型存储着多个 文档 ,每个文档又有 多个 属性 。

    • 类似关系:

      索引-数据库   /  类型-表  /  文档-表中的记录  /   属性-列

    put :放数据
    get :获取数据
    head:检查是否存在该数据,有则响应200,没有就404
    
    
    http://192.168.0.113:9200/megacorp/employee/1
    
    {
        "first_name" : "John",
        "last_name" : "Smith",
        "age" : 25,
        "about" : "I love to go rock climbing",
        "interests" : [ "sports","music"]
    }
    
    
    {
        "first_name" : "Jane",
        "last_name" : "Smith",
        "age" : 32,
        "about" : "I like to collect rock albums",
        "interests" : [ "music"]
    }
    
    
    {
        "first_name" : "Douglas",
        "last_name" : "Fir",
        "age" : 35,
        "about" : "I like to build cabinets",
        "interests" : [ "forestry"]
    }
    
    http://192.168.0.113:9200/megacorp/employee/_search
    
    http://192.168.0.113:9200/megacorp/employee/_search?q=last_name:Smith
    
    
    
    
    get没有请求体,所以放到post请求里面
    
    轻量搜索:
    {
    "query" : {
        "match" : {
            "last_name" : "Smith"
        }
    }
    }
    
    全文检索:
    字段包含rock /   climbing  都可能出现
    {
    "query" : {
        "match" :{
        "about" : "rock climbing"
        }
    }
    }
    
     "max_score": 0.53484553   :  相关性得分
    
    
     短语搜索:
     内容完全匹配才会展示 
     {
    "query" : {
        "match_phrase" :{
        "about" : "rock climbing"
        }
    }
    }
    
    高亮搜索:
     {
    "query" : {
        "match_phrase" :{
        "about" : "rock climbing"
        }
    },
    "highlight" : {
        "fields" : {
        "about" : {}
        }
    }
    }
    结果:
    <em>rock</em> <em>climbing</em>
  • 相关阅读:
    elementui 修改合计行样式
    C# 导出Excel NPOI 修改指定单元格的样式 或者行样式
    向基于语义模型的操作集成的演变
    在制造业的工业2.0中应用MOM系统
    制造运营管理 (MOM) 的工作流驱动方法
    语义模型在智能工业运营中的作用
    定义运营系统架构
    在离散混合制造环境中应用制造运营模型
    面试官:如果存取IP地址,用什么数据类型比较好 (C#版本)
    使用WtmPlus低代码平台提高生产力
  • 原文地址:https://www.cnblogs.com/MagicAsa/p/10882078.html
Copyright © 2011-2022 走看看