.Net使用ElasticSearch

文章目录

  • 前言
  • 主体内容
    • 一.Kibana中ElasticSearch的基础操作
      • 1.GET(查询)
      • 1.POST(新增)
      • 1.PUT(修改)
      • 1.DELET(删除)
    • 二.在.Net中,对ElasticSearch进行基础操作
      • 1.DotNet连接ElasticSearch
      • 2.DotNet查询ElasticSearch指定Index的数据
        • a.这里用了一些NEST包的查询条件,非常的不方便
        • b.使用Kibana中的ES语句查询ElasticSearch
        • c.使用Sql语句查询ElasticSearch(需要单独下载对应版本的ElasticSearch-Sql插件)
      • 3.DotNet新增ElasticSearch数据
      • 4.DotNet修改ElasticSearch数据
      • 5.DotNet删除ElasticSearch数据

前言

Elastic官网:https://www.elastic.co/guide/en/elasticsearch/reference/current/eql.html#specify-a-timestamp-or-event-category-field

CSDN大佬的ElasticSearch和Kibana安装通道

本文章的主要目的就是了解ElasticSearch的基本用法,以及在.Net中简单操作一些ElasticSearch的数据

Elasticsearch 是一个开源的分布式搜索和分析引擎,它被设计用来快速、准确地进行大规模数据的搜索和分析。Elasticsearch 基于 Apache Lucene 搜索引擎构建,提供了一个分布式的实时文档存储和检索引擎,适用于各种用例,包括文本搜索、日志分析、应用程序性能监控等。

以下是 Elasticsearch 的一些主要特点和用途:

全文搜索:Elasticsearch 支持全文搜索,可以快速检索大量的文本数据,并提供相关性排序和高亮显示等功能。

实时数据分析:Elasticsearch 具有实时性,可以快速索引新数据并立即使其可查询,适用于实时监控和分析场景。

分布式架构:Elasticsearch 是分布式的,数据被自动分片存储在集群中的多个节点上,提供了高可用性和横向扩展性。

多种用途:Elasticsearch 可以用于各种用例,包括搜索引擎、日志和指标分析、安全信息和事件管理等。

RESTful API:Elasticsearch 提供了基于 RESTful API 的交互方式,方便与各种编程语言和工具集成。

强大的聚合功能:Elasticsearch 提供了丰富的聚合功能,可以对数据进行统计、分组、过滤等操作。

总的来说,Elasticsearch 是一个功能强大且灵活的搜索和分析引擎,广泛应用于企业级应用程序中,为用户提供快速、准确的数据搜索和分析能力。

主体内容

一.Kibana中ElasticSearch的基础操作

进入Kibana在左侧的菜单栏中,有一个开发工具,里面可以进行简单的ElasticSearch命令操作
注意:ElasticSearch中的语言类型为强类型语言,命令字符GET(查询),POST(新增),PUT(修改),DELETE(删除)只能以大写为前缀;document中的字段建议小写,在.Net中操作的时候大写前缀会无法辨别,
在这里插入图片描述

1.GET(查询)

查询所有索引(Index)

GET _search

查询指定索引

GET user/_search

添加查询条件
这里推荐一个在线sql格式转es格式转换工具 PrintLove:https://old.printlove.cn/tools/sql2es
这个网址可以将我们熟知的sql语句转换成es所需的条件语句,另外这里还有几个其他格式文档的转换
在这里插入图片描述

这样我们在kibana中就能执行对应的条件过滤了

GET user/_search
{
    "query": {
        "bool": {
            "must": [
                {
                    "match_phrase": {
                        "name": {
                            "query": "黄"
                        }
                    }
                }
            ]
        }
    },
    "from": 0,
    "size": 1
}

在这里插入图片描述

使用sql语句查询,获得txt格式数据

GET /_sql?format=txt
{
  "query": "SELECT * FROM user"
}

在这里插入图片描述
使用sql语句查询,获得json格式数据

GET /_sql?format=json
{
  "query": "SELECT * FROM user"
}

在这里插入图片描述

1.POST(新增)

命令格式 POST user/_doc/id 其中id不指定,系统会自动生成一个字符串id

POST user/_doc
{
  "name":"hgcjd",
  "age":18
}

在这里插入图片描述

1.PUT(修改)

命令格式 PUT index/_doc/id

PUT user/_doc/b2B_O44B65XW4Pz-I4W7
{
  "name":"hgcjd2",
  "age":18
}

在这里插入图片描述

1.DELET(删除)

命令格式 Delete index/_doc/id

Delete user/_doc/b2B_O44B65XW4Pz-I4W7

在这里插入图片描述

二.在.Net中,对ElasticSearch进行基础操作

这里我使用的是.net6的控制台程序,需要安装NEST包
在这里插入图片描述

1.DotNet连接ElasticSearch

连接成功后,//开始执行操作占位符,就可以放其他的es操作代码块了

var settings = new ConnectionSettings(new Uri("https://localhost:9200/"))
    //.DefaultIndex("user") //可以在连接ElasticSearch的时候,就选择Index
    .BasicAuthentication("elastic", "你的elastic密码")
    // 忽略证书验证,仅用于测试环境,请勿在生产环境中使用
    .ServerCertificateValidationCallback((sender, certificate, chain, sslPolicyErrors) => true);

var client = new ElasticClient(settings);
var clusterHealth = client.Cluster.Health();
if (clusterHealth.IsValid){
	//开始执行操作
}else{
	Console.WriteLine($"ElasticSearch连接失败{clusterHealth.OriginalException.Message}");
}

添加一个User类

public class User
{
    public string Id { get; set; }

    public string Name { get; set; }

    public int Age { get; set; }
}

2.DotNet查询ElasticSearch指定Index的数据

a.这里用了一些NEST包的查询条件,非常的不方便
#region 查询数据
    var searchResponse = await client.SearchAsync<User>(s => s.Index("user") //选择Index,否则程序会异常
                                                                             //.From((1 - 1) * 10) //取数启始位置
                                                                             //.Size(10)   //指定页面大小
                                                                             //.Query(e=>e.Range(r=>r.Field(f=>f.Age).GreaterThanOrEquals(18).LessThan(80)))    //查询条件:年龄大于等于18 并且 年龄小于80 
                                                                             //.Query(e=>e.Prefix(r=>r.Field(f=>f.Name).Value("黄")))   //查询条件:名字以"黄"字开头
                                                                             //.Query(e => e.Match(r => r.Field(f => f.Name).Query("尔")))  //查询条件:名字包含"尔"字
                                                                             //.Sort(s=>s.Field(f=>f.Age,SortOrder.Descending))   //根据年龄降序排序
        );
    if (searchResponse.IsValid)
    {
        foreach (var hit in searchResponse.Hits)
        {
            var model = new User()
            {
                Id = hit.Id,
                Name = hit.Source.Name,
                Age = hit.Source.Age,
            };
            Console.WriteLine($"ID:{model.Id};\t姓名:{model.Name};\t年龄:{model.Age}");
            //userList.Add(model);
        }
        //Console.WriteLine(JsonConvert.SerializeObject(userList));
    }
    else
    {
        Console.WriteLine($"查询失败:{searchResponse.OriginalException.Message}");
    }
    #endregion

在这里插入图片描述

b.使用Kibana中的ES语句查询ElasticSearch

这里获取到的结果是一个很长的json字符串,还需要单独解析

 var searchResponse = client.LowLevel.Search<StringResponse>("user", @"{
      ""query"": {
      ""bool"": {
        ""must"": [
          {
            ""match_all"": { }
          }
        ],
        ""must_not"": [ ],
        ""should"": [ ]
        }
      },
      ""from"": 0,
      ""size"": 10,
      ""sort"": [ ],
      ""aggs"": { }
    }");

    if (searchResponse.Success)
    {
        Console.WriteLine(searchResponse.Body); // 处理查询结果
    }
    else
    {
        Console.WriteLine($"Error executing search query: {searchResponse.OriginalException.Message}");
    }

在这里插入图片描述

c.使用Sql语句查询ElasticSearch(需要单独下载对应版本的ElasticSearch-Sql插件)

github大佬的ElasticSearch-Sql安装地址,找到对应的ES版本:https://github.com/NLPchina/elasticsearch-sql/releases
我安装的es版本太新了,是elasticsearch-8.12.2版本的,看了一下大佬的插件版本,还没有更新到这

#region 使用sql查询
var sql = "select * from user where age > 18 Order by age desc";
//var url = "https://localhost:9200/_sql?format=json";//返回json格式数据
var url = "https://localhost:9200/_sql?format=txt";//返回txt格式数据

//忽略SSL认证
ServicePointManager.ServerCertificateValidationCallback += (sender, certificate, chain, sslPolicyErrors) => true;

HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
var data = Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(new { query = sql }));
request.Accept = "application/json;charset=UTF-8";
request.Method = "POST";
request.ContentType = "application/json";
request.Timeout = 90000;

//账号密码认证
NetworkCredential credential = new NetworkCredential("elastic", "你的密码");
request.Credentials = credential;
using (var strea = request.GetRequestStream())
{
    strea.Write(data,0,data.Length);
}
var response = (HttpWebResponse)request.GetResponse();
using (var resStream = response.GetResponseStream())
{
    using (var reader = new StreamReader(resStream,Encoding.UTF8))
    {
        Console.WriteLine(reader.ReadToEnd());
    }
}
#endregion

在这里插入图片描述

3.DotNet新增ElasticSearch数据

#region 新增数据
var UserInfo = new User()
{
    Name = "黄瓜炒鸡蛋",
    Age = 20,
};
var addResponse = client.IndexDocument(UserInfo);
if (addResponse.IsValid)
{
    Console.WriteLine($"新增ID为{addResponse.Id}的数据成功");
}
else
{
    Console.WriteLine($"操作失败:{addResponse.OriginalException.Message}");
}
#endregion

4.DotNet修改ElasticSearch数据

下面的bmB9O44B65XW4Pz-foX9为数据Id

#region 修改数据
var updateResponse = client.Update<User>("bmB9O44B65XW4Pz-foX9", u => u
.Index("user") // 替换为你的索引名称
.Doc(new User
{
    Name = "福尔摩斯",
    Age = 35,
})
);

if (updateResponse.IsValid)
{
    Console.WriteLine("修改成功");
}
else
{
    Console.WriteLine("修改失败: " + updateResponse.OriginalException.Message);
}
#endregion

5.DotNet删除ElasticSearch数据

下面的cGCFO44B65XW4Pz-M4X5为数据Id

#region 删除数据
var deleteResponse = client.Delete<User>("cGCFO44B65XW4Pz-M4X5", d => d
.Index("user") // 替换为你的索引名称
);

if (deleteResponse.IsValid)
{
    Console.WriteLine("删除成功");
}
else
{
    Console.WriteLine("删除失败 " + deleteResponse.OriginalException.Message);
}
#endregion

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/465596.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【爬虫逆向】Python逆向采集猫眼电影票房数据

进行数据抓包&#xff0c;因为这个网站有数据加密 !pip install jsonpathCollecting jsonpathDownloading jsonpath-0.82.2.tar.gz (10 kB)Preparing metadata (setup.py) ... done Building wheels for collected packages: jsonpathBuilding wheel for jsonpath (setup.py) .…

Acwing-基础算法课笔记之动态规划(区间DP)

Acwing-基础算法课笔记之动态规划&#xff08;区间DP&#xff09; 一、石子合并1、定义2、闫氏DP分析法3、模拟过程4、代码示例 一、石子合并 1、定义 设有 N N N堆石子排成一排&#xff0c;其编号为 1 1 1&#xff0c; 2 2 2&#xff0c; 3 3 3&#xff0c;…&#xff0c; N…

SAP前台处理:销售业务集成<VA03/VL03N/VLPOD/VF03) 02/02

接上一章节&#xff1a; 下方&#xff1a;按照行项目显示&#xff1a;物料信息、数量信息、地点信息&#xff08;工厂、移动类型、库位&#xff09;、批次信息、科目分配信息&#xff08;科目分配对象&#xff09; 点击FI凭证&#xff0c;跳转到成本结转凭证或发出商品凭证界…

微信小程序的页面制作---常用组件及其属性

微信小程序里的组件就是html里的标签&#xff0c;但其组件都自带UI风格和特定的功能效果 一、常用组件 view&#xff08;视图容器&#xff09;、text&#xff08;文本&#xff09;、button&#xff08;按钮&#xff09;、image&#xff08;图片&#xff09;、form&#xff08…

大数据 - Spark系列《十三》- spark调度流程(运行过程)

Spark系列文章&#xff1a; 大数据 - Spark系列《一》- 从Hadoop到Spark&#xff1a;大数据计算引擎的演进-CSDN博客 大数据 - Spark系列《二》- 关于Spark在Idea中的一些常用配置-CSDN博客 大数据 - Spark系列《三》- 加载各种数据源创建RDD-CSDN博客 大数据 - Spark系列《…

完美解决 RabbitMQ可视化界面Overview不显示折线图和队列不显示Messages

问题场景&#xff1a; 今天使用docker部署了一个RabbitMQ&#xff0c;浏览器打开15672可视化页面发送消息后不显示Overview中的折线图&#xff0c;还有队列中的Messages&#xff0c;因为我要看队列中的消息数量。 解决方案&#xff1a; 进入容器内部 docker exec -it 容器id…

走进Hyperledger Fabric:企业区块链技术的简明介绍

该文章Github地址&#xff1a;https://github.com/AntonyCheng/blockchain-notes 在此介绍一下作者开源的SpringBoot项目初始化模板&#xff08;Github仓库地址&#xff1a;https://github.com/AntonyCheng/spring-boot-init-template & CSDN文章地址&#xff1a;https://…

GPT-SoVITS语音合成服务器部署(远程访问)

GPT-SoVITS 是一个开源项目&#xff0c;它使用大约一分钟的语音数据便可以训练出一个优秀的TTS模型。 项目的核心技术是 Zero-shot TTS 和 Few-shot TTS。 Zero-shot TTS 可以让用户输入5秒钟的语音样本并立即体验转换后的语音&#xff0c;而 Few-shot TTS 则可以通过使用仅一…

静默安装OGG21.3微服务版本FOR ORACLE版本

静默安装OGG21.3微服务版本FOR ORACLE版本 silent install ogg21.3 for oracle 某度找来找去都没有找到一份可靠的静默安装OGG21.3微服务版本的案例&#xff0c;特别难受&#xff0c;为此将自己静默安装的步骤一步步贴出来分享给大家&#xff0c;请指点&#xff0c;谢谢。 至…

【赠书第20期】AI绘画与修图实战:Photoshop+Firefly从入门到精通

文章目录 前言 1 入门篇&#xff1a;初识Photoshop与Firefly 2 进阶篇&#xff1a;掌握Photoshop与Firefly的核心技巧 3 实战篇&#xff1a;运用Photoshop与Firefly进行创作 4 精通篇&#xff1a;提升创作水平&#xff0c;拓展应用领域 5 结语 6 推荐图书 7 粉丝福利 前…

解决谷歌浏览器最新chrome94版本CORS跨域问题

项目场景&#xff1a; 谷歌浏览器升级到chrome94版本出现CORS跨域问题 问题描述 解决谷歌浏览器最新chrome94版本CORS跨域问题。 CORS跨域问题&#xff1a; 升级谷歌浏览器最新chrome94版本后&#xff0c;提示Access to XMLHttpRequest at ‘http://localhost:xxxx/api’ fro…

【机器学习系列】M3DM工业缺陷检测部署与训练

一.基础资料 1.Git 地址 地址 2.issues issues 3.参考 参考 csdn 二.服务器信息 1.GPU 服务器 GPU 服务器自带 CUDA 安装(前提是需要勾选上)CUDA 需要选择大于 11.3 的版本登录服务器后会自动安装 GPU 驱动 2.CUDA 安装 GPU 服务器自带 CUDA CUDA 版本查看 3.登录信…

安装Pinia 插件 pinia-plugin-persist 添加 persist 属性时报红线解决方法

1&#xff0c;使用全局状态管理pinia 添加persist包红线&#xff0c; 网上很多都没有得到实际的解决方法。 2&#xff0c;接下来给大家梳理一下正确的解决方法&#xff1b; 首先卸载pinia-plugin-persist pnpm uninstall pinia-plugin-persist 安装pinia-plugin-persistedsta…

Git——修改历史记录详解

目录 Git1、修改历史信息1.1、启动互动模式1.2、修改Commit信息的影响1.3、取消Rebase 2、多个Commit合并位一个Commit3、一个Commit拆解成多个Commit4、在某些Commit之间插入新的Commit5、删除Commit6、调整Commit的顺序7、Revert指令7.1、取消Commit7.2、取消Revert1、再开一…

【金三银四】掌趣科技24.3.7 H项目 服务端开发笔试题

考试题型&#xff1a; 不定项选择题 10 道 &#xff0c; 填空题 10 道 &#xff0c; 问答题 2 道 &#xff0c; 编程题 4 道 目录 不定项选择题 10 道填空题 10 道问答题 2 道编程题 4 道 不定项选择题 10 道 在TCP协议中&#xff0c;发送方的窗口大小是由两个关键因素共同决定…

Java八股文(MyBatis Plus)

Java八股文のMyBatis Plus MyBatis Plus MyBatis Plus MyBatis Plus 是什么&#xff1f;它与 MyBatis 有什么区别&#xff1f; MyBatis Plus 是基于 MyBatis 进行扩展的一款持久层框架&#xff0c;它提供了一系列增强功能&#xff0c;简化了 MyBatis 的使用。 与 MyBatis 相比…

SpringBoot(文件上传功能,阿里云OSS存储,几种配置文件用法)【详解】

目录 一、新增员工 二、文件上传-技术点 1. 文件上传功能 1.客户端上传文件三要素 2 服务端接收文件 Controller接收文件示例 修改允许上传的文件大小 2. 本地存储文件 3. 阿里云OSS存储&#xff08;这里只写一种&#xff0c;可以用其它的&#xff09; 1.介绍 2.开通…

力扣L14--- 415.字符串相加(JAVA版)-2024年3月17日

1.题目 2.知识点 注1&#xff1a;你可以使用Integer.parseInt()或Double.parseDouble()等方法将字符串转换为整数或浮点数。 public class Main {public static void main(String[] args) {String str "123";int num Integer.parseInt(str);System.out.println(…

深度序列模型与自然语言处理:基于TensorFlow2实践

目录 写在前面 推荐图书 编辑推荐 内容简介 作者简介 推荐理由 写在最后 写在前面 本期博主给大家推荐一本深度学习的好书&#xff0c;对Python深度学习感兴趣的小伙伴快来看看吧&#xff01; 推荐图书 《深度序列模型与自然语言处理 基于TensorFlow2实践》 直达链接…

iOS常见崩溃简介

1. 崩溃 多指在移动设备&#xff08;如iOS、Android设备&#xff09;中或不可移动设备&#xff08;如:Windows、Linux等设备&#xff09;&#xff0c; 在打开或使用应用程序时出现的突然退出中断的情况&#xff08;类似于Windows的应用程序崩溃&#xff09;。 多表现为&#…
最新文章