利用NEST2.0 在C#中操作Elasticsearch
前言:本文主要演示了如何通过c#来操作elasticsearch,分两个方面来演示:
索引数据
搜索数据
Note: 注意我索引数据和搜索数据是两个不同的例子,没有前后依赖关系
准备工作:需要在visual studio 用NuGet 搜索 NEST,下载NEST 2.3即可
注意elasticsearch和 NEST的版本,版本差异可能会导致写法不同
一、 索引数据演示
下面的c#代码有如下要点:
1. 通过es服务器 localhost:9200来定义es client
2. 导入前通过定义字段类型的类,自动mapping
var mappingBlogPost = elastic.Map(s => s.AutoMap());
Resume 这个类要提前根据数据类型进行定义:
using System;
namespace BotEsNest
{
using Nest;
[ElasticsearchType(Name = "candidate", IdProperty = "Id")]
public class Resume
{
[String(Name = "id", Index = FieldIndexOption.NotAnalyzed)]
public Guid? Id { get; set; }
[String(Name = "name", Index = FieldIndexOption.Analyzed)]
public string Name { get; set; }
[String(Name = "age", Index = FieldIndexOption.NotAnalyzed)]
public long Age { get; set; }
[String(Name = "skills", Index = FieldIndexOption.Analyzed)]
public string Skills { get; set; }
}
}
3. 构造数据
4. 导入数据
using Nest;
using System;
using System.Linq;
namespace BotEsNest
{
public class ImportEs
{
public static string ElasticsearchMethod()
{
var node = new Uri("http://localhost:9200");
var indexName = "esbot";
var settings = new ConnectionSettings(node).DefaultIndex(indexName);
var elastic = new ElasticClient(settings);
var res = elastic.ClusterHealth(); //
Console.WriteLine(res.Status);
if (!elastic.IndexExists(indexName).Exists)
{
var createIndexResponse = elastic.CreateIndex(indexName);
var mappingBlogPost = elastic.Map<Resume>(s => s.AutoMap());
//Console.WriteLine("createIndexResponse=" + createIndexResponse.IsValid);
//Console.WriteLine("mappingBlogPost=" + mappingBlogPost.IsValid);
}
string[] nameArray = { "Cody", "Blake", "Dennis", "Evan ", "Harris", "Jason ", "Lambert ", "Louis ", "Milton ", "Cody" };
string[] skillArray = { "c#", "c++", "java", "python", "php", "Linux", "ruby", "matlab", "perl", "powershell" };
long[] ageRange = { 24, 25, 26, 27, 28, 29, 30, 31, 32, 33 };
for (int i = 0; i < 10; i++)
{
var resume = new Resume
{
Id = Guid.NewGuid(),
Name = nameArray[i],
Age = ageRange[i],
Skills = "My skill is Azure and " + skillArray[i]
};
IIndexResponse bulkIndexReponse = elastic.Index(resume, p => p
.Type(typeof(Resume))
.Id(i)
.Refresh());
}
var searchResult = elastic.Search<Resume>(sr => sr.Query(q => q.MatchAll()));
//Console.WriteLine(searchResult.Hits.Count());
//Console.ReadLine();
var resumesCount = searchResult.Hits.Count().ToString();
return resumesCount;
}
}
}
搜索返回的信息都包含在searchResult中。索引esbot也已经创建。可以通过Kibana或者REST API进行查看
二、搜索数据演示
1. 此处的数据源是es官网的bank account,我已经提前手动导入
2. 搜索数据的关键在于用lambda表达式构造搜索内容,下段代码是为了动态定制参数所做
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Web;
namespace BotEsNest.Ext
{
public class Extension
{
public static Dictionary<string, Expression<Func<Resume, object>>> ResumeDIctionary()
{
return new Dictionary<string, Expression<Func<Resume, object>>>
{
{ "age",p=>p.Age},
{ "name",p=>p.Name}
};
}
public static Dictionary<string, Expression<Func<Bank, object>>> BankDictionary()
{
return new Dictionary<string, Expression<Func<Bank, object>>>
{
{ "account_number",p=>p.account_number},
{ "age",p=>p.age},
{"balance",p=>p.balance},
};
}
}
}
3.定义搜索类型
using Nest;
namespace BotEsNest
{
[ElasticsearchType(Name = "account", IdProperty = "Id")]
public class Bank
{
public long account_number { get; set; }
public string address { get; set; }
public long age { get; set; }
public long balance { get; set; }
public string city { get; set; }
public string email { get; set; }
public string employer { get; set; }
public string firstname { get; set; }
public string gender { get; set; }
public string lastname { get; set; }
public string state { get; set; }
}
}
4. 搜索,我大概写了三种搜索方式,比如:返回存款在40000到40100的人,返回数据中带有Miltoon的人,返回数据中带有35的人,返回结构存在searchResponse中
using System;
using Nest;
using BotEsNest.Ext;
namespace BotEsNest
{
public class Elasticsearch
{
public static string indexName = "bank";
public static Uri node = new Uri("http://localhost:9200");
public static ConnectionSettings settings = new ConnectionSettings(node).DefaultIndex(indexName);
public static ElasticClient elastic = new ElasticClient(settings);
public static ISearchResponse<Bank> esSearchNumber()
{
string dictionaryKey = "balance";
var dictionary = Extension.BankDictionary();
var rangeField = dictionary[dictionaryKey];
var gt = 40000;
var lt = 40100;
var searchResponse = elastic.Search<Bank>(es => es
.Query(q => q
.Range(r => r
.Name("")
.Field(rangeField)
.GreaterThan(gt)
.LessThan(lt)
.Boost(2.0))));
return searchResponse;
}
public static ISearchResponse<Bank>esSearchString()
{
string quertStr = "Miltoon";
var searchResponse = elastic.Search<Bank>(es => es
.Query(q =>
q.QueryString(qs => qs.Query(quertStr))));
return searchResponse;
}
public static ISearchResponse<Bank>esSearchField()
{
string queryStr = "35";
string dictionaryKey = "age";
var dictionary = Extension.BankDictionary();
var rangeField = dictionary[dictionaryKey];
var searchResponse = elastic.Search<Bank>(es => es
.Query(q => q
.Match(m => m
.Field(rangeField)
.Query(queryStr))));
return searchResponse;
}
}
}
利用NEST2.0 在C#中操作Elasticsearch的更多相关文章
- 《SeleniumBasic 3.141.0.0 - 在VBA中操作浏览器》系列文章之一:SeleniumBasic的下载
Selenium是一种非常流行的浏览器和网页自动化技术,开发人员可以使用C#.Java.Python等语言来操作Chrome.Firefox等浏览器. VBA语言可以直接操作访问Microsoft I ...
- Elastic:Sense chrome - 在 chrome 浏览器中操作 Elasticsearch 的插件
文章转载自:https://elasticstack.blog.csdn.net/article/details/114533904 Sense 是我们现在所说的 Kibana 控制台 UI 的第一个 ...
- 【译】在Asp.Net中操作PDF - iTextSharp - 利用列进行排版
原文 [译]在Asp.Net中操作PDF - iTextSharp - 利用列进行排版 在使用iTextSharp通过ASP.Net生成PDF的系列文章中,前面的文章已经讲述了iTextSharp所涵 ...
- 【译】在Asp.Net中操作PDF – iTextSharp -利用块,短语,段落添加文本
原文 [译]在Asp.Net中操作PDF – iTextSharp -利用块,短语,段落添加文本 本篇文章是讲述使用iTextSharp这个开源组件的系列文章的第三篇,iTextSharp可以通过As ...
- 【译】在Asp.Net中操作PDF - iTextSharp - 利用列进行排版(转)
[译]在Asp.Net中操作PDF - iTextSharp - 利用列进行排版 在使用iTextSharp通过ASP.Net生成PDF的系列文章中,前面的文章已经讲述了iTextSharp所涵盖 ...
- android4.0以上访问网络不能在主线程中进行以及在线程中操作UI的解决方法
MONO 调用一个线程操作UI 然后报Only the original thread that created a view hierarchy can touch its views.错误 goo ...
- elk快速入门-在kibana中如何使用devtools操作elasticsearch
在kibana中如何使用devtools操作elasticsearch:前言: 首先需要安装elasticsearch,kibana ,下载地址 https://www.elastic.co/cn/d ...
- MVC4.0 利用IActionFilter实现简单的后台操作日志功能
首先我们要了解MVC提供了4种常用的拦截器:IActionFilter(Action拦截器接口).IExceptionFilter(异常拦截器接口).IResultFilter(Result拦截器接口 ...
- 如何在python中使用Elasticsearch
什么是 Elasticsearch 想查数据就免不了搜索,搜索就离不开搜索引擎,百度.谷歌都是一个非常庞大复杂的搜索引擎,他们几乎索引了互联网上开放的所有网页和数据.然而对于我们自己的业务数据来说 ...
随机推荐
- Python从菜鸟到高手(2):清空Python控制台
执行python命令会进入Python控制台.在Python控制台中可以用交互的方式执行Python语句.也就是执行一行Python语句,会立刻返回执行结果. 当Python控制台输入过多的Pyt ...
- Nagios图像绘制插件PNP4Nagios部署和测试
注:本篇博客Nagios版本Nagios-3.5.1 1. 概述2. 关于PNP4Nagios3. 部署PNP4Nagios3.1 下载PNP4Nagios3.2 编译安装3.3 目录文件说明4. 配 ...
- JAVA中使用MD5加密实现密码加密
1.新建Md5.java 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 package c ...
- 对于windows 10使用感受
windows 10是美国微软公司研发的新一代跨平台及设备应用的操作系统.在2015年7月29日12点起,windows 10推送全面开始,windows 7.windows 8 用户可以升级到win ...
- Linux内核及分析 第三周 Linux内核的启动过程
实验过程: 打开shell终端,执行以下命令: cd LinuxKernel/ qemu -kernel linux-3.18.6/arch/x86/boot/bzImage-initrd rootf ...
- OSGB数据压缩
OSGB数据输出时压缩数据大小,采用如下设置 osgDB::writeNodeFile(*osgbNode, "xxx/xxxx.osgb", new osgDB::Options ...
- Windows 7 64位安装cURL
安装cURL. 1, 下载64位的SSL版cURL,网址: http://curl.download.nextag.com/download/curl-7.21.7-win64-ssl-sspi.zi ...
- java学习--第50天讲到jquery
4月4日jquery讲完了. jquery组合选择器 逗号隔开 层级选择器 父元素 子元素,直接子元素和间接子元素,空格隔开. 直接后代选择器: 父元素>子元素 选择的直接子元素 下 ...
- PAT 1071 小赌怡情
https://pintia.cn/problem-sets/994805260223102976/problems/994805264312549376 常言道“小赌怡情”.这是一个很简单的小游戏: ...
- C++ cout执行顺序
C++ cout执行顺序 问题描述是这样的:如果在cout中调用函数,同时这个函数中包含输出语句,那么会先输出哪一句? 仔细一看,突然发现对C++的内容遗忘了,确实一下子看不出来输出的先后问题. 实现 ...