ElasticSearch NEST搜索
var client = ElasticsearchHelper.GetElasticClient("order");
QueryContainer termQuery = new TermQuery() { Field = "lastname", Value = "求和" };
var result = client.Search<Order>(s => s
.Aggregations(a => a
.Sum("my_sum_agg", sa => sa
.Field(p => p.TotalPrice)
)
)
);
var agg = result.Aggs.Sum("my_sum_agg");
var searchResults = client.Search<Order>(s => s
// .Query(termQuery) //带筛选条件
.Aggregations(r => r.Terms("firstname", r1 => r1.Field(r2 => r2.Lastname)
.OrderAscending("sumprice")
.Aggregations(y => y.Sum("sumprice", y1 => y1.Field(y2 => y2.TotalPrice))))));
var carTypes = searchResults.Aggs.Terms("firstname");
List<double> re=new List<double>();
foreach (var carType in carTypes.Items)
{
string key = carType.Key;
System.Console.WriteLine("key:" + key + " total:" + carType.Sum("sumprice").Value);
re.Add((double)carType.Sum("sumprice").Value);
}
//List<SumTotalPrice> orders = searchResults.Documents.ToList();
// System.Console.WriteLine(orders.Count() + " total:" + searchResults.Total);
//System.Console.WriteLine(searchResults.RequestInformation);
System.Console.ReadLine();
#endregion
#region 多条件精确匹配
var client = ElasticsearchHelper.GetElasticClient("order");
QueryContainer termQuery = new TermQuery() { Field = "firstname", Value = "测试" };
QueryContainer wholeWordQuery = new TermQuery() { Field = "lastname", Value = "addddd" };
//非索引字段。无法查询 此查询条件无效
QueryContainer termQuery1 = new TermQuery() { Field = "content", Value = " 天空是百度的1696" };
termQuery = (termQuery || wholeWordQuery) || termQuery1;
var searchResults = client.Search<Order>(s => s
.From(0)
.Size(10)
.Query(termQuery)
);
List<Order> orders = searchResults.Documents.ToList();
System.Console.WriteLine(orders.Count() + " total:" + searchResults.Total);
System.Console.ReadLine();
#endregion
#region 精确匹配
var client = ElasticsearchHelper.GetElasticClient("order");
var searchResults = client.Search<Order>(s => s
.From(0)
.Size(10)
.Query(q => q.Term(r => r.OnField(k => k.Firstname).Value("棉花")))
.Highlight(h => h.OnFields(e => e.OnField("firstname")
.PreTags("<b style='color:black'>")
.PostTags("</b>")))
.Sort(r => r.Descending().OnField(q => q.Createtime))
);
List<Order> orders = searchResults.Documents.ToList();
System.Console.WriteLine(orders.Count() + " total:" + searchResults.Total);
System.Console.ReadLine();
#endregion
ElasticSearch NEST搜索的更多相关文章
- ElasticSearch NEST笔记
ElasticSearch NEST笔记 1. 什么是ElasticSearch? ElasticSearch is a powerful open source search and analyti ...
- Elasticsearch实现搜索推荐词
本篇介绍的是基于Elasticsearch实现搜索推荐词,其中需要用到Elasticsearch的pinyin插件以及ik分词插件,代码的实现这里提供了java跟C#的版本方便大家参考. 1.实现的结 ...
- Creating a custom analyzer in ElasticSearch Nest client
Creating a custom analyzer in ElasticSearch Nest client Question: Im very very new to elasticsearch ...
- Elasticsearch NEST – Examples for mapping between Query and C#
Elasticsearch NEST – Examples for mapping between Query and C# During my training with Elasticsearch ...
- ElasticSearch位置搜索
ElasticSearch位置搜索 学习了:https://blog.csdn.net/bingduanlbd/article/details/52253542 学习了:https://blog.cs ...
- ElasticSearch入门-搜索(java api)
ElasticSearch入门-搜索(java api) package com.qlyd.searchhelper; import java.util.Map; import net.sf.json ...
- PHP使用ElasticSearch做搜索
PHP 使用 ElasticSearch 做搜索 https://blog.csdn.net/zhanghao143lina/article/details/80280321 https://www. ...
- 十九种Elasticsearch字符串搜索方式终极介绍
前言 刚开始接触Elasticsearch的时候被Elasticsearch的搜索功能搞得晕头转向,每次想在Kibana里面查询某个字段的时候,查出来的结果经常不是自己想要的,然而又不知道问题出在了哪 ...
- Elasticsearch 为了搜索
前言 Elasticsearch 是一个开源的搜索引擎,建立在一个全文搜索引擎库 Apache Lucene 基础之上. Lucene 可以说是当下最先进.高性能.全功能的搜索引擎库--无论是开源还是 ...
随机推荐
- JSP的动态导入
<body> <!-- 动态引入 他们引入的相互独立的代码段 所以可以运行 代码段之间存在重复的变量 --> this is a test dy include 01 < ...
- how to deal with EINTR fault
[how to deal with EINTR fault] EINTR:interupted error.是指一个调用被信号给中断,对于同步的耗时调用来说,这个操作常见,譬如select.read. ...
- 在制MO未取到FP
原因:今天在制MO未取进去原因为业务人员维护验货客户尾缀时维护ZZ导致,需更新为C开头即可 SELECT * FROM IN_SFCHEADER WHERE MO_ID in('00110051832 ...
- centos7之saltstack安装
查阅来自salt官网:http://docs.saltstack.cn/topics/installation/rhel.html To install using the SaltStack rep ...
- marioTcp
https://github.com/nicholaszj/marioTcp MarioTCP MarioTCP 是使用libevent模型来建立的一个性能强大的TCP服务器. 1:Getting S ...
- web02
高内聚,低耦合 写what 不写how 我们只关心他是什么,得到什么,我们并不关心怎么去得到的 ,那个细节去怎么得的, 都应该在这个层面上屏蔽掉,要关心的时候在点进去,这样就一层层的结构良好的代码 d ...
- 使用tengine解决负载均衡的session问题
事情的经过时这样的~~,我看了好多好多百度中nginx负载均衡中解决session问题的方式,我选择了研究url_hash的方式.经过一番配置之后,我越发觉得这百度搜出来的帖子也太过久远了吧,去htt ...
- android Service 的简单使用(转)
1.要使用Service,首先就是在配置文件里吗添加Service,如果不填加,你的Service是不能够使用的.目前学到的方法有两种 方法一:<service android:enabl ...
- python 中feedParser
转载于https://www.cnblogs.com/bbn0111/p/7056366.html.学习使用 参考链接:http://blog.csdn.net/lanchunhui/article/ ...
- 看图说话:关于BI那点事儿
[编者按]BI=DW+数据挖掘+业务分析+社会学?BI三部曲:管数据.看数据.源数据.BI有三种放法:技术部.业务部和独立部门.BI的工作=20%数据平台+30%数据支持+50%数据应用.