.net core中简单使用NEST发布ElasticSearch api

作者使用的NEST版本7.11.1
官方文档https://www.elastic.co/guide/en/elasticsearch/client/net-api/7.x/nest-getting-started.html

测试API类代码

using Nest;
using System;
using System.Collections.Generic;

namespace TestAPI.Models
{
    public class StudentAPI
    {
        private ElasticClient _client;
        public static string ConnectionSettings = "http://192.168.1.156:9200";

        public static string IndexName = "student";

        private static int _size = 20;
        public StudentAPI() 
        {
            var settings = new ConnectionSettings(new Uri(ConnectionSettings))
                        .DefaultIndex(IndexName);
            _client = new ElasticClient(settings);
        }
        /// <summary>
        /// 创建索引
        /// </summary>
        /// <returns></returns>
        public bool CreateIndex() {

            try
            {
                dynamic response = _client.Indices.Get(IndexName);
                if (!response.IsValid)
                {
                    response = _client.Indices.Create(IndexName, c => c
                    .Map<Student>(m => m
                        .AutoMap()
                    ));
                    Console.WriteLine(response);
                }
                return true;
            }
            catch (Exception e)
            {
                return false;
                throw;
            }
        }

        /// <summary>
        /// 删除索引
        /// </summary>
        /// <returns></returns>
        public bool DeleteIndex() 
        {
            try
            {
                //根据名称删除索引
                var response = _client.Indices.Delete(IndexName);
                return true;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 添加文档
        /// </summary>
        /// <param name="stu"></param>
        /// <returns></returns>
        public bool Add(Student stu) 
        {
            try
            {

                var indexResponse = _client.Index(stu, i => i.Index(IndexName).Id(stu.ID));

                if (!indexResponse.IsValid)
                {
                    // If the request isn't valid, we can take action here
                    return false;
                }
                return true;
            }
            catch (Exception e)
            {
                return false;
                throw;
            }
        }
        /// <summary>
        /// 批量添加文档
        /// </summary>
        /// <param name="lists"></param>
        /// <returns></returns>
        public bool BulkDescriptor(List<Student> lists)
        {
            try
            {
                //批量创建文档
                BulkDescriptor descriptor = new BulkDescriptor();
                for (int i = 0; i < lists.Count; i++)
                {
                    var stu = lists[i];
                    descriptor.Index<Student>(op => op.Document(stu).Index(IndexName).Id(stu.ID));
                }

                var response = _client.Bulk(descriptor);
                return true;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 根据ID删除文档
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public bool Delete(string id) 
        {
            try
            {
                //根据特定的条件来删除文档
                var response = _client.Delete<Student>(id, d => d.Index(IndexName));

                //删除文档
                //response = _client.Delete<Student>(id.CompanyID);
                return true;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 更新文档
        /// </summary>
        /// <param name="stu"></param>
        /// <returns></returns>
        public bool Updelete(Student stu) 
        {
            try
            {
                var response = _client.Index(stu, i => i.Id(stu.ID));
                //修改指定版本的文档
                //response = _client.Index(stu, i => i.Id(stu.CompanyID).Version(1));
                return true;
            }
            catch (Exception)
            {
                throw;
                return false;
            }
        }

        
        /// <summary>
        /// 获取索引中所有文档
        /// </summary>
        /// <returns></returns>
        public IReadOnlyCollection<Student> GetAll()
        {
            try
            {

                var str = "";
                var searchResponse = _client.Search<Student>(s => s
                    .Index(IndexName)
                    .Query(q => q
                        .MatchAll()
                    )
                );

                return searchResponse.Documents;
            }
            catch (Exception e)
            {
                return null;
                throw;
            }
            
        }
        /// <summary>
        /// 分页查询,keyword过滤所有字段
        /// </summary>
        /// <param name="keyword"></param>
        /// <param name="page"></param>
        /// <returns></returns>
        public IReadOnlyCollection<Student> GetAllField(string keyword, int page)
        {
            try
            {
                var searchAll = _client.Search<Student>(s => s
                    .Index(IndexName)
                    .From(page)
                    .Size(_size)
                    .Query(q => q
                        .QueryString(qs => qs
                            .Query(keyword).DefaultOperator(Operator.And))
                        ));

                return searchAll.Documents;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 分页查询,根据Name获取文档
        /// </summary>
        /// <param name="keyword"></param>
        /// <param name="page"></param>
        /// <returns></returns>
        public IReadOnlyCollection<Student> GetByName(string keyword,int page)
        {
            try
            {
                var searchResponse = _client.Search<Student>(s => s
                     .Index(IndexName)
                     .From(page)
                     .Size(_size)
                     .Query(q => q
                        .Match(m => m
                            .Field(
                                f => f.Name
                            )
                            .Query(keyword))
                        ));

                return searchResponse.Documents;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 查询所有,选择Name,ID,Age,三个字段输出数据
        /// </summary>
        /// <returns></returns>
        public IReadOnlyCollection<Student> GetSelectFields()
        {
            try
            {

                var searchResponse = _client.Search<Student>(s => s
                    .Index(IndexName)
                    .Source(fs => fs
                        .Includes(fh => fh   //包含以下字段
                            .Fields(
                                f => f.Name,
                                f => f.ID,
                                f => f.Age
                            )
                        )
                        .Excludes(e => e    //排除以下字段
                            .Fields(   
                                f => f.Birthday,
                                f => f.IsManager
                            )   
                        )
                    )
                    .Query(q => q
                        .MatchAll()
                    )
                );

                return searchResponse.Documents;
            }
            catch (Exception)
            {

                throw;
            }
        }
        /// <summary>
        /// 分页查询,根据Name,Birthday字段
        /// </summary>
        /// <param name="keyword"></param>
        /// <param name="sdate"></param>
        /// <param name="edate"></param>
        /// <param name="page"></param>
        /// <returns></returns>
        public IReadOnlyCollection<Student> GetByNameAndDay(string keyword, DateTime sdate, DateTime edate, int page)
        {
            try
            {
                var searchResponse = _client.Search<Student>(s => s
                    .Index(IndexName)
                    .From(page)
                    .Size(_size)
                    .Query(q => q
                        .Bool(b => b
                            .Must(mu => mu
                                .Match(m => m
                                    .Field(f => f.Name)
                                    .Query(keyword)
                                )
                            )
                            .Filter(fi => fi
                                 .DateRange(r => r
                                    .Field(f => f.Birthday)
                                    .GreaterThanOrEquals(sdate)
                                    .LessThan(edate)
                                )
                            )
                        )
                    )
                );

                另一个写法
                //var searchResponse = _client.Search<Project>(s => s
                //    .Query(q => q
                //        .Match(m => m
                //            .Field(f => f.FirstName)
                //            .Query("许")
                //        ) && q
                //        .Match(m => m
                //            .Field(f => f.LastName)
                //            .Query("嵩")
                //        ) && +q
                //        .DateRange(r => r
                //            .Field(f => f.StartedOn)
                //            .GreaterThanOrEquals(new DateTime(2017, 01, 01))
                //            .LessThan(new DateTime(2018, 01, 01))
                //        )
                //    )
                //);

                return searchResponse.Documents;
            }
            catch (Exception)
            {

                throw;
            }
        }
    }
}

linux中发布.net core api参考:
链接: https://www.jianshu.com/p/5fda6340ce22.

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.NET Core WebAPI 进行依赖注入 Elasticsearch,您需要按照以下步骤进行操作: 1. 首先,您需要在 WebAPI 项目安装 Elasticsearch.NET 客户端,您可以使用 NuGet 包管理器来安装。 2. 在 WebAPI 项目定义 Elasticsearch 的客户端服务,以便在应用程序注入 Elasticsearch 客户端依赖项。您可以在 Startup.cs 文件的 ConfigureServices 方法注册 Elasticsearch 客户端服务。 3. 建立 Elasticsearch 客户端连接,以便在 WebAPI 项目使用 Elasticsearch 客户端进行数据检索。您可以在 Startup.cs 文件的 Configure 方法创建 Elasticsearch 客户端连接。 以下是示例代码: ```csharp // 1. 安装 Elasticsearch.NET 客户端 // Install-Package Nest // 2. 定义 Elasticsearch 客户端服务 public void ConfigureServices(IServiceCollection services) { // 添加 Elasticsearch.NET 客户端服务 services.AddSingleton<IElasticClient>(s => { var settings = new ConnectionSettings(new Uri("http://localhost:9200")); return new ElasticClient(settings); }); } // 3. 建立 Elasticsearch 客户端连接 public void Configure(IApplicationBuilder app, IWebHostEnvironment env, IElasticClient elasticClient) { // 建立 Elasticsearch 客户端连接 var response = elasticClient.Ping(); if (!response.IsValid) { // 处理连接失败的情况 } } ``` 在您注册了 Elasticsearch 客户端服务之后,您可以通过构造函数注入 IElasticClient 接口来使用 Elasticsearch 客户端。例如,如果您要在控制器使用 Elasticsearch 客户端进行数据检索,您可以按照以下方式进行操作: ```csharp [ApiController] [Route("[controller]")] public class MyController : ControllerBase { private readonly IElasticClient _elasticClient; public MyController(IElasticClient elasticClient) { _elasticClient = elasticClient; } [HttpGet] public async Task<IActionResult> Get() { var response = await _elasticClient.SearchAsync<MyDocument>(s => s .Index("myindex") .From(0) .Size(10) .Query(q => q.MatchAll()) ); if (!response.IsValid) { // 处理数据检索失败的情况 } return Ok(response.Documents); } } ``` 在上面的示例,我们注入了 IElasticClient 接口,并在 Get 方法使用它来执行数据检索操作。您可以根据实际情况使用不同的 Elasticsearch 客户端 API,例如 Index、Update、Delete 等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值