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测试页面效果

ElasticSearch.net NEST批量创建修改删除索引完整示例

本示例采用Elasticsearch+Nest网上查了很多资料,发现用C#调用Elasticsearch搜索引擎的功能代码很分散,功能不完整,多半是非常简单的操作,没有成型的应用示例。比如新增或修改索...
  • qq_18145031
  • qq_18145031
  • 2016-12-02 19:57:48
  • 3420

ELaticSearch——PlainElastic.net.dll 中的JsonNetSerializer

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

elasticsearch 5.x highlight 高亮

elasticsearch 5.x highlight 高亮
  • chengyuqiang
  • chengyuqiang
  • 2017-01-03 09:56:11
  • 5767

Elasticsearch.Net使用(二)【MVC4 图书管理系统】

首先项目结构图: Model层的相关代码如下: Book.cs代码如下: public class Book { [Key] [DatabaseGen...
  • WuLex
  • WuLex
  • 2016-08-07 19:19:14
  • 4622

Elasticsearch.Net Nest 5.0.0 用法

Elasticsearch.Net Nest 5.0.0 用法
  • wyqlxy
  • wyqlxy
  • 2017-04-28 10:17:54
  • 1193

Elasticsearch.Net使用(一)【入门篇】

首先去官网下载Elasticsearch 2.3.4安装包,解压后,在cmd命令行进入安装目录,再进入 bin目录,运行elasticsearch.bat命令 elasticsearch插件elast...
  • WuLex
  • WuLex
  • 2016-08-06 22:25:56
  • 6386

Elasticsearch(二)【Elasticsearch.Net基本使用】

低级客户端ElasticLowLevelClient是一个低级的,无依赖的客户端,对如何构建和表示您的请求和响应没有意见。它可以从Visual Studio中的包管理器控制台安装使用Install-P...
  • WuLex
  • WuLex
  • 2017-03-22 14:09:45
  • 3323

ElasticSearch——.NET客户端

NEST elasticsearch的官方高级.NET客户端。 它旨在成为一个坚实,强类型的客户端,具有非常简洁的API。 内部使用低级Elasticsearch.Net客户端的高级客户端使用流畅...
  • Shiyaru1314
  • Shiyaru1314
  • 2016-11-24 16:16:59
  • 1016

.NET 分布式 搜索 elasticsearch.net NEST

我们公司(电商)目前使用 elasticsearch。对于一个3亿数据量索引查询速度都是在毫秒级别,不过实现都是基于JAVA的client. 本人因为是.NET出身,虽然现在做JAVA。但是对.NET...
  • kingson88
  • kingson88
  • 2016-04-26 18:07:11
  • 2714

elasticsearch.net search入门使用指南中文版(翻译)

elasticsearch.net search入门使用指南中文版(翻译)
  • wyqlxy
  • wyqlxy
  • 2017-04-19 15:15:28
  • 800
收藏助手
不良信息举报
您举报文章:plainelastic.net elasticsearch实现搜索业务
举报原因:
原因补充:

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