plainelastic.net elasticsearch实现搜索业务

转载 2017年10月18日 10:42:32
本文介绍使用plainelastic elasticsearch先介绍api使用方法,然后给出一个实现搜索业务的一个plainelastic.net实例教程 1、PlainElastic.Net下载 1)源码下载:https://github.com/Yegoroff/PlainElastic.Net 2)通
本文介绍使用plainelastic elasticsearch先介绍api使用方法,然后给出一个实现搜索业务的一个plainelastic.net实例教程

 1、PlainElastic.Net下载

  1)源码下载:https://github.com/Yegoroff/PlainElastic.Net

  2)通过NuGet Packages下载

  使用plainelastic elasticsearch实现搜索业务

  备注:通过这种方式下载,有可能因为PlainElastic.Net引用的Newtonsoft.Json.dll版本与原有项目中的不一致到报错,因此建议下载源码,将源码中的Newtonsoft.Json.dll版本更换为当前项目的版本

 2、封装PlainElastic.Net帮助类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using PlainElastic.Net;
using PlainElastic.Net.Queries;
using PlainElastic.Net.Serialization;

namespace Amy.Toolkit.PlainElastic
{
    public class ElasticSearchHelper
    {
        public static readonly ElasticSearchHelper Intance = new ElasticSearchHelper();

        private ElasticConnection Client;

        private ElasticSearchHelper()
        {
            Client = new ElasticConnection("localhost", 9200);
        }

        /// <summary>
        /// 数据索引
        /// </summary>       
        /// <param name="indexName">索引名称</param>
        /// <param name="indexType">索引类型</param>
        /// <param name="id">索引文档id,不能重复,如果重复则覆盖原先的</param>
        /// <param name="jsonDocument">要索引的文档,json格式</param>
        /// <returns>索引结果</returns>
        public IndexResult Index(string indexName, string indexType, string id, string jsonDocument)
        {

            var serializer = new JsonNetSerializer();

            string cmd = new IndexCommand(indexName, indexType, id);

            OperationResult result = Client.Put(cmd, jsonDocument);

            var indexResult = serializer.ToIndexResult(result.Result);

            return indexResult;
        }

        /// <summary>
        /// 数据索引
        /// </summary>       
        /// <param name="indexName">索引名称</param>
        /// <param name="indexType">索引类型</param>
        /// <param name="id">索引文档id,不能重复,如果重复则覆盖原先的</param>
        /// <param name="jsonDocument">要索引的文档,object格式</param>
        /// <returns>索引结果</returns>
        public IndexResult Index(string indexName, string indexType, string id, object document)
        {
            var serializer = new JsonNetSerializer();

            var jsonDocument = serializer.Serialize(document);

            return Index(indexName, indexType, id, jsonDocument);
        }

        /// <summary>
        /// 全文检索
        /// </summary>
        /// <typeparam name="T">搜索类型</typeparam>
        /// <param name="indexName">索引名称</param>
        /// <param name="indexType">索引类型</param>
        /// <param name="query">查询条件(单个字段或者多字段或关系)</param>
        /// <param name="from">当前页(0为第一页)</param>
        /// <param name="size">页大小</param>
        /// <returns>搜索结果</returns>
        public SearchResult<T> Search<T>(string indexName, string indexType, QueryBuilder<T> query, int from, int size)
        {
            var queryString = query.From(from).Size(size).Build();
            
            var cmd = new SearchCommand(indexName, indexType);

            var result = Client.Post(cmd, queryString);

            var serializer = new JsonNetSerializer();

            return serializer.ToSearchResult<T>(result);
        }
    }
}

 3、在control中的实现

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using PlainElastic.Net;
using PlainElastic.Net.Queries;
using Amy.WebUI.Controllers;


namespace Amy.WebUI.Areas.Admin.Controllers
{
    public class SearchController : BasicController
    {
        /// <summary>
        /// 创建索引/更新索引
        /// </summary>
        public ActionResult AddIndexByPlainElastic(Models.SearchObject model)
        {
            if (string.IsNullOrEmpty(model.Id))
            {
                model.Id = IDHelper.Id32;
            }

            model.DateTime = DateTime.Now;

            var result = Amy.Toolkit.PlainElastic.ElasticSearchHelper.Intance.Index("db_test", "searchobject", model.Id, model);

            return JRCommonHandleResult(!string.IsNullOrEmpty(result._id));
        }

        /// <summary>
        /// 搜索数据
        /// </summary>
        public ActionResult SearchByPlainElastic(string key, int page = 0)
        {
            #region 定义查询内容
            var query = new QueryBuilder<Models.SearchObject>()
                //查询,多字段匹配(Title和Content匹配key中的任意一个单词)
                .Query(x =>
                    x.QueryString(t => t.Fields(obj => obj.Title, obj => obj.Content).Query(key))
                )
                //过滤,数据为启用状态并且大小在40~150之间
                .Filter(x => 
                    x.And(w=>
                        w.Term(t => t
                            .Field(obj => obj.IsEnable).Value("true")
                        )
                        .Range(t => t
                            .Field(obj => obj.Size).From("40").To("150")
                        )
                    )
                )
                //排序,按照时间倒序排列
                .Sort(x => x.Field("DateTime", SortDirection.desc))
                //高亮,定义高亮样式及字段
                .Highlight(h => h
                    .PreTags("<b>")
                    .PostTags("</b>")
                    .Fields(
                        f => f.FieldName("Title").Order(HighlightOrder.score),
                        f => f.FieldName("Content").Order(HighlightOrder.score),
                        f => f.FieldName("_all")
                    )
                );
            #endregion

            var result = Amy.Toolkit.PlainElastic.ElasticSearchHelper.Intance.Search<Models.SearchObject>("db_test", "searchobject", query, page, 10);

            #region 拼装查询内容
            var list = result.hits.hits.Select(c => new Models.SearchObject()
            {
                Id = c._source.Id,
                Title = c.highlight == null ? c._source.Title : c.highlight.Keys.Contains("Title") ? string.Join("", c.highlight["Title"]) : c._source.Title, //高亮显示的内容,一条记录中出现了几次
                Content = c.highlight == null ? c._source.Content : c.highlight.Keys.Contains("Content") ? string.Join("", c.highlight["Content"]) : c._source.Content, //高亮显示的内容,一条记录中出现了几次
                Size = c._source.Size,
                IsEnable = c._source.IsEnable,
                DateTime = c._source.DateTime,
            }).ToPageList(page + 1, 10, result.hits.total);
            #endregion

            return JRSuccess(list.ToJsonByJsonNet());
        }

    }
}

 4、代码中使用到的伪搜索对象

namespace Amy.WebUI.Areas.Admin.Models
{
    public class SearchObject
    {
        public string Id { get; set; }

        public string Title { get; set; }

        public string Content { get; set; }

        public int Size { get; set; }

        public bool IsEnable { get; set; }

        public DateTime DateTime { get; set; }
    }
}

 5、UI测试页面效果

ELaticSearch——PlainElastic.net.dll 中的JsonNetSerializer

之前为了尽量减少对ES类库的使用,对于ES查询返回的结果,直接使用NewtonJson的json转化器, 结果最后发现搜索结果的Json中有聚合的结果,但是转化成SearchResult 就怎么也看...

ElasticSearch的Java API

1.与ES服务集群交互方式 可以通过两种方式来连接到elasticsearch(简称es)集群,第一种是通过在你的程序中创建一个嵌入es节点(Node),使之成为es集群的一部分,然后通过这个节点来与...

Elasticsearch过滤与聚合的先后顺序java实现

Elasticsearch的聚合结果是先过滤或者搜索后聚合,那么如果我们想要先聚合,然后对结果进行再一次的过滤或者搜索应该如何实现呢,在此给出简单的java实现demo...

Elasticsearch Date类型使用技巧

elasticsearch原生支持date类型,结合该类型和Kibana可以做出漂亮有用的图表。这里简单记录下使用的方法。 使用date类型可以用如下两种方式: 使用毫秒的时间戳,直接...
  • F7ANTY
  • F7ANTY
  • 2015年10月20日 16:04
  • 3301

elasticsearch 创建type及插入数据

创建 type ("store":"yes") PUT my_index {   "mappings": {     "type_one": {       "properties": { ...
  • bzqgo
  • bzqgo
  • 2016年05月21日 11:04
  • 3752

.NET 业务框架开发实战之九 Mapping属性原理和验证规则的实现策略

前言:之前的讨论一直关注在怎么从DAL中获取数据,以及数据的Mapping问题。实际上,一个业务框架最主要的作用就是简化业务逻辑的编写和开发。     本篇的议题如下: 框架的借鉴综合考...

使用.net core ABP和Angular模板构建博客管理系统(实现自己的业务逻辑)

之前写到使用.net core ABP 和Angular模板构建项目,创建后端服务。文章地址:http://www.jianshu.com/p/fde1ea20331f 创建完成后的api基本是...

ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装

ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2):数据库访问层的设计Demo    (3):面向接口编程   前言:前面几篇博客我...
  • txqqnet
  • txqqnet
  • 2013年10月10日 21:01
  • 1445

.NET实现模拟MQTT通信(业务逻辑以及关键实现)

许久不更新了,最近这段时间发生挺多事,说破了也就应届生那点破事,什么技术方向,等待offer,签约毁约的。最终还是老老实实回到公司继续实习,为了以后再拼搏一次吧。 最近公司做的项目中有用到消息推送,...

.NET 分布式 搜索 elasticsearch.net NEST

我们公司(电商)目前使用 elasticsearch。对于一个3亿数据量索引查询速度都是在毫秒级别,不过实现都是基于JAVA的client. 本人因为是.NET出身,虽然现在做JAVA。但是对.NET...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:plainelastic.net elasticsearch实现搜索业务
举报原因:
原因补充:

(最多只允许输入30个字)