之前的文章中曾经探讨过如何动态的构造searchrequest,今天我们来探讨下如何使用.net core 像python那样运行dsl语句
- 定义model
using Nest;
using Elasticsearch.Net;
namespace coreEsLowLever.Models
{
public class Ellis
{
[DoubleRange(Name="value")]
public double Value { get; set; }
[Text(Name = "name")]
public string Name { get; set; }
}
}
- 定义helper
需要注意的是,之前我们在构造searchrequest的时候,已经设置了index的名称,但是这里通过string构造searchrequest的时候并没有设置,因此ConnectionSettings 里需要添加DefaultMappingFor,这时候再去查询相应的model时候会使用设置好的index名称
using coreEsLowLever.Models;
using Elasticsearch.Net;
using Nest;
using System.Text;
namespace coreEsLowLever.EsHelper
{
public class Helper
{
public ElasticClient _elaticClient;
public Helper()
{
SingleNodeConnectionPool pool = new SingleNodeConnectionPool(new Uri("http://192.168.214.133:31200"));
ConnectionSettings setting = new ConnectionSettings(pool).BasicAuthentication("elastic", "ellischen").EnableDebugMode()
.DefaultMappingFor<Ellis>(x => x.IndexName("ellis"))
.DefaultIndex("elli*");
_elaticClient = new ElasticClient(setting);
}
public object runDsl(string indexName,string dsl)
{
var json = @"{
""query"": {
""match_all"":{}
}
}";
SearchRequest<Ellis> searchRequest;
using (var stream = new MemoryStream(Encoding.UTF8.GetBytes(json)))
{
searchRequest = _elaticClient.SourceSerializer.Deserialize<SearchRequest<Ellis>>(stream);
}
//var value = _elaticClient.Search<Object>(searchRequest);
//return value;
//SearchRequest searchRequest = new SearchRequest<Ellis>()
//{
// Query = new MatchAllQuery()
//};
var value = _elaticClient.Search<Ellis>(searchRequest);
return value.Documents;
}
}
}