前言:本文主要演示了如何通过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 ...
-
【译】在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 想查数据就免不了搜索,搜索就离不开搜索引擎,百度.谷歌都是一个非常庞大复杂的搜索引擎,他们几乎索引了互联网上开放的所有网页和数据.然而对于我们自己的业务数据来说 ...
-
kibana7.x安装配置操作elasticsearch
什么是Kibana? Kibana是一个基于Node.js的Elasticsearch索引库数据统计工具,可以利用Elasticsearch的聚合功能,生成各种图表,如柱形图,线状图,饼图等. 而且还 ...
随机推荐
-
ref与out之间的区别
ref和out都是C#中的关键字,所实现的功能也差不多,都是指定一个参数按照引用传递.对于编译后的程序而言,它们之间没有任何区别,也就是说它们只有语法区别. 总结起来,他们有如下语法区别: 1.ref ...
-
计算机缺失缺少mfc110.dll等相关文件的解决办法
去https://www.microsoft.com/zh-CN/download/details.aspx?id=30679下载 VSU4\vcredist_x64.exe 和VSU4\vcredi ...
-
iOS,XMPP本地环境搭建和框架使用
1.XMPP的MySQL和openfire环境配置 2.XmppFramework框架导入和介绍 XMPP的MySQL和openfire环境配置 1.下载mysql安装 mysql下载 打开MySQL ...
-
Poetize6: Acting Cute
3042: Acting Cute Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 59 Solved: 36[Submit][Status] Des ...
-
2.3 LINQ查询表达式中 使用select子句 指定目标数据
本篇讲解LINQ查询的三种形式: 查询对象 自定义查询对象某个属性 查询匿名类型结果 [1.查询结果返回集合元素] 在LINQ查询中,select子句和from子句都是必备子句.LINQ查询表达式必须 ...
-
Fiddler简介
官网:http://www.telerik.com/fiddler Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的HTTP通讯,设置断点,查看所有的" ...
-
MySQL数据库对象-索引
1. 概述2. 索引分类2.1 不同索引的概念2.1.1 普通索引2.1.2 唯一索引2.1.3 全文索引2.1.4 多列索引3. 索引操作3.1 普通索引3.1.1 创建表时创建普通索引3.1.2 ...
-
一个有趣的python排序模块:bisect
今天同事说到了一个python的排序模块bisect,觉得挺有趣的,跟大家分享分享. 先看看模块的结构: 前面五个属性大家感兴趣可以打出来看看数值,这里就不介绍了. 先说明的是,使用这个模块的函数前先 ...
-
jQuery框架开发一个最简单的幻灯效果
在线演示 在这个课程中,我们将介绍如何使用jQuery来开发一个最简单的图片幻灯效果. 立刻观看互动课程:jQuery框架开发一个最简单的幻灯效果 阅读原文:jQuery框架开发一个最简单的幻灯效果
-
platform平台总线
一.何为平台总线 (1)相对于usb.pci.i2c等物理总线来说,platform总线是虚拟的.抽象出来的.(2)CPU与外部通信的2种方式:地址总线式连接和专用协议类接口式连接.平台总线,是扩展到 ...