當前位置: 首頁>>代碼示例>>C#>>正文


C# ElasticClient.Search方法代碼示例

本文整理匯總了C#中Nest.ElasticClient.Search方法的典型用法代碼示例。如果您正苦於以下問題:C# ElasticClient.Search方法的具體用法?C# ElasticClient.Search怎麽用?C# ElasticClient.Search使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Nest.ElasticClient的用法示例。


在下文中一共展示了ElasticClient.Search方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SearchDoesNotTakeDefaultIndexIntoAccount

		[U] public void SearchDoesNotTakeDefaultIndexIntoAccount()
		{
			var node = new Uri("http://localhost:9200");
			var connectionPool = new SingleNodeConnectionPool(node);
			var connectionSettings = new ConnectionSettings(connectionPool, connection: new InMemoryConnection())
				.DefaultIndex("logstash-*")
				.DefaultFieldNameInferrer(p => p)
				.OnRequestCompleted(info =>
				{
					// info.Uri is /_search/ without the default index
					// my ES instance throws an error on the .kibana index (@timestamp field not mapped because I sort on @timestamp)
				});

			var client = new ElasticClient(connectionSettings);
			var response = client.Search<ESLogEvent>(s=>s);

			response.ApiCall.Uri.AbsolutePath.Should().Be("/logstash-%2A/eslogevent/_search");

			response = client.Search<ESLogEvent>(new SearchRequest<ESLogEvent>{ });
			response.ApiCall.Uri.AbsolutePath.Should().Be("/logstash-%2A/eslogevent/_search");

			response = client.Search<ESLogEvent>(new SearchRequest { });
			response.ApiCall.Uri.AbsolutePath.Should().Be("/_search");

		}
開發者ID:c1sc0,項目名稱:elasticsearch-net,代碼行數:25,代碼來源:GithubIssue1906.cs

示例2: Main

        static void Main(string[] args)
        {
            elasticSettings = new ConnectionSettings(new Uri("http://127.0.0.1:9200"))
                .SetDefaultIndex("people");

            client = new ElasticClient(elasticSettings);

            ///// ** Basic search with QueryString
            var searchResults = client.Search<Person>(s => s.Query(q => q.
                                                    QueryString(x => x.Query("toto").
                                                                        OnField(of => of.LastName))));

            foreach (var result in searchResults.Documents)
            {
                Console.WriteLine("Found: {0}", result.FirstName + " " + result.LastName);
            }

            ///// ** Basic search on Message
            //var searchResults = client.Search<Person>(s => s.Query(q => q.
            //    QueryString(x => x.Query("brother").
            //        OnField(of => of.Message).
            //        Operator((Operator.and)))));

            //foreach (var result in searchResults.Documents)
            //{
            //    Console.WriteLine("Found: {0}", result.FirstName + " " + result.LastName);
            //}

            Console.ReadKey();
        }
開發者ID:jptoto,項目名稱:esdotnet,代碼行數:30,代碼來源:Program.cs

示例3: SearchList

 public static List<NewsBase> SearchList(string nid)
 {
     string espath = ConfigurationManager.AppSettings["ESPath"].ToString();
     string indexname = ConfigurationManager.AppSettings["IndexName"].ToString();
     string typename = ConfigurationManager.AppSettings["TypeName"].ToString();
     var node = new Uri(espath);
     var settings = new ConnectionSettings(node);
     var client = new ElasticClient(settings);
     //keyword = String.Format("*{0}*", keyword);
     var searchResults = client.Search<NewsBase>(s => s
         .Index(indexname)
         .Type(typename)
         .Query(q => q.QueryString(qs => qs.Query(nid).DefaultOperator(Operator.And)))
         .Sort(st => st.OnField(f => f.newsid).Order(SortOrder.Descending))  /*按ID排序,id為數字,排序正常*/
         //.Sort(st=>st.OnField(f=>f.PubDate.Suffix("sort")).Descending())   /*按時間排序,時間格式,排序bug;中文字符串bug*/
         .From(0)
         .Size(1)
     );
     List<NewsBase> eslist = new List<NewsBase>(searchResults.Documents);
     //foreach (var data in searchResults.Documents)
     //{
     //    eslist.Add(data);
     //}
     return eslist;
 }
開發者ID:starckgates,項目名稱:ForSearch,代碼行數:25,代碼來源:Content.aspx.cs

示例4: Index

        // GET: Search
        public ActionResult Index(string r)
        {
            var uri = new Uri("https://IlwEAOgvDkuHk3yiB74RhwSs1YC0KCUu:@aniknaemm.east-us.azr.facetflow.io");
            var settings = new ConnectionSettings(uri).SetDefaultIndex("indexdem");
            var client = new ElasticClient(settings);

            var result = client.Search<Demotivator>(q => q
            .Query(f => f
               .QueryString(t => t.Query(r + "*").OnFields(u => u.Name)) || f
               .QueryString(t => t.Query(r + "*").OnFields(u => u.Str1)))

            );
            SearchViewModel model = new SearchViewModel();
            List<Demotivator> tr = new List<Demotivator>();

            foreach (var t in result.Hits)
            {

                var sleep = (Demotivator)t.Source;
                int temp = new int();

                if (sleep != null)
                {

                    tr.Add(sleep);
                }
                else
                {
                }

            }
            model.demotivators = tr;
            return View(model);
        }
開發者ID:itstep2014springEvening,項目名稱:IDemotivator,代碼行數:35,代碼來源:SearchController.cs

示例5: GetJournalItemsFromElastic

        internal static IQueryable<UAutoContractJournalItem> GetJournalItemsFromElastic(Uri node, SearchRequest request)
        {
            var settings = new ConnectionSettings(
                node,
                defaultIndex: "uauto");

            var client = new ElasticClient(settings);

            var searchResult = client.Search<UAutoContractJournalItem>(request);

            return searchResult.Documents.AsQueryable();
        }
開發者ID:andreychizhov,項目名稱:NestQueryableProvider,代碼行數:12,代碼來源:JournalItemsQueryContext.cs

示例6: PerformSearch

        public IHttpActionResult PerformSearch([FromUri] string indexName, 
            [FromUri] string searchTerm)
        {
            SampleConfiguration config = new SampleConfiguration();
            esNode = new Uri(config.ElasticsearchServerHost);
            connectionSettings = new ConnectionSettings(esNode, defaultIndex: indexName);
            esClient = new ElasticClient(connectionSettings);

            var esResults = esClient.Search<Product>(s => s
                .Query(p => p.MatchPhrase(m => m.OnField("name").Query(searchTerm)))
                //.Filter(f => f.Range(r => r.OnField("price").GreaterOrEquals(10).LowerOrEquals(20)))
                );

            return Ok(esResults.Documents);
        }
開發者ID:ElasticsearchTraining,項目名稱:ElasticsearchWebApiSample,代碼行數:15,代碼來源:SearchController.cs

示例7: Search

        public JsonResult Search(string term)
        {
            var uri = new Uri("https://IlwEAOgvDkuHk3yiB74RhwSs1YC0KCUu:@aniknaemm.east-us.azr.facetflow.io");
            var settings = new ConnectionSettings(uri).SetDefaultIndex("indexdem");
            var client = new ElasticClient(settings);

            var result = client.Search<Demotivator>(q => q
            .Query(f => f
               .QueryString(t => t.Query(term + "*").OnFields(u => u.Name)) || f
               .QueryString(t => t.Query(term + "*").OnFields(u => u.Str1)))

            );

            return Json(result.Hits.Select(t => t.Source), JsonRequestBehavior.AllowGet);
        }
開發者ID:itstep2014springEvening,項目名稱:IDemotivator,代碼行數:15,代碼來源:SearchController.cs

示例8: SearchDoesntLowercaseStringFieldOverload

        public void SearchDoesntLowercaseStringFieldOverload()
        {
            var settings = new ConnectionSettings(Test.Default.Uri).SetDefaultIndex(Test.Default.DefaultIndex);
            var client = new ElasticClient(settings);
            var result = client.Search<SomeOtherClass>(s => s
              .SortDescending("CreateDate2")
              .FacetDateHistogram("CreateDate2", fd => fd.OnField("CreateDate2").Interval(DateInterval.Hour))
              .Query(query => query.Range(r=>r
                  .OnField("CreateDate2")
                  .From(DateTime.UtcNow.AddYears(-1))

                )
              )
            );
            StringAssert.DoesNotContain("createDate2", result.ConnectionStatus.Request);
        }
開發者ID:occ,項目名稱:NEST,代碼行數:16,代碼來源:PropertyNameResolverTests.cs

示例9: SearchFood

        public IEnumerable<Food> SearchFood(string Name)
        {
            var EsClient = new ElasticClient();

            var ES_Search = EsClient.Search<Food>(s => s
            .Index("food")
            .Type(Name)
            .From(0)
            .Size(10)
            .Query(q => q
                        .QueryString(ps => ps
                        .DefaultField(o => o.Name)

            )));
            return ES_Search.Documents;
        }
開發者ID:aecuman,項目名稱:Test,代碼行數:16,代碼來源:FoodRepo.cs

示例10: SearchUsesTheProperResolver

 public void SearchUsesTheProperResolver()
 {
     var settings = new ConnectionSettings(new Uri("http://localhost:9200")).SetDefaultIndex(Test.Default.DefaultIndex);
       var client = new ElasticClient(settings);
       var result = client.Search<SomeOtherClass>(s => s
     .SortDescending(f=>f.MyCustomOtherClass.MyProperty)
     .Query(query => query
       .Bool(bq => bq
     .Must(
       mq => mq.ConstantScore(cs => cs.Filter(filter => filter.Term(x => x.MyCustomClass.MyProperty, "meesageid"))),
       mp => mp.ConstantScore(cs => cs.Filter(filter => filter.Term(x => x.MyCustomOtherClass.MyProperty, "serverid")))
     )
       )
     )
       );
       StringAssert.Contains("custom.MID", result.ConnectionStatus.Request);
       StringAssert.Contains("myCustomOtherClass.MID", result.ConnectionStatus.Request);
 }
開發者ID:digitalhurricane,項目名稱:NEST,代碼行數:18,代碼來源:PropertyNameResolverTests.cs

示例11: GetMessage

 public IHttpActionResult GetMessage(int id)
 {
     //var message = messages.FirstOrDefault((m) => m.Id == id);
     client = this.Connect();
     var results = client.Search<Message>(s => s
                                             .From(0)
                                             .Size(10)
                                             .Query(q => q
                                                  .Term(m => m.Id, id)
         )
     );
     var message = results.Documents.FirstOrDefault();
     if (message == null)
     {
         return NotFound();
     }
     return Ok(message);
 }
開發者ID:n0ble,項目名稱:AI,代碼行數:18,代碼來源:MessageController.cs

示例12: ElasticSearchTest

        private static void ElasticSearchTest()
        {
            var node = new Uri("http://localhost:9200");

            var settings = new ConnectionSettings(
                node,
                defaultIndex: "my-application"
            );

            var client = new ElasticClient(settings);

            Product product = new Product("Tv", DateTime.Now, 200, new string[] { "45''", "48''" });

            var index = client.Index(product);

            ISearchResponse<Product> searchResults = client.Search<Product>(s => s.MatchAll());
            Product prd = searchResults.Hits.FirstOrDefault().Source;
        }
開發者ID:nmalocic,項目名稱:JsonSerialziation,代碼行數:18,代碼來源:Program.cs

示例13: elasticSearch

        public void elasticSearch() {


            var uri = new Uri("http://localhost:9200");
            var settings = new ConnectionSettings(uri).SetDefaultIndex("contacts");
            var client = new ElasticClient(settings);

            if (client.IndexExists("contacts").Exists)
            {

                UpsertContact(client, new Contacts(1,"Andrew Kagwa", "Uganda"));
                Console.WriteLine("Indexing Successfull");
            }
            else
            {

            }



            Console.ReadKey();

            QueryContainer query = new TermQuery
            {
                Field = "Name",
                Value = "Andrew",
                 
                
            };

            var searchReq = new SearchRequest
            {

                From = 0,
                Size = 10,
                Query = query,
            };

            var result = client.Search<Contacts>(searchReq);



        }
開發者ID:akagwa1,項目名稱:NEWRedisRestApp,代碼行數:43,代碼來源:ElasticSearch.cs

示例14: CreatePersonWithImageAttachment

        public void CreatePersonWithImageAttachment()
        {
            var node = new Uri("http://localhost:9200");

            var settings = new ConnectionSettings(
                node,
                defaultIndex: "my-application"
            );

            var client = new ElasticClient(settings);
            //client.DeleteIndex("index-name");
            client.CreateIndex("index-name", c => c
                 .AddMapping<Document>(m => m.MapFromAttributes())
              );

            string path = "c:\\test.png";

            var attachment = new Attachment
            {
                Content = Convert.ToBase64String(File.ReadAllBytes(path)),
                ContentType = "image/jpeg",
                Name = "IMG_9896.JPG"
            };

            var person = new Person
            {
                Id = Convert.ToString(new Random(DateTime.Now.Second).Next(20000)),
                Firstname = "Martijn",
                Lastname = "Laarman",
                File = new[] { attachment }
            };

            var index = client.Index(person);

            var results = client.Search<Person>(s => s
                .From(0)
                .Size(10)
                .Query(q => q
                     .Term(p => p.Firstname, "martijn")
                )
            );
        }
開發者ID:ThomasMentzel,項目名稱:Hello.ElasticSearch,代碼行數:42,代碼來源:PersonWithAttachments.cs

示例15: GetNearest

        public IEnumerable<NearestNoteModel> GetNearest(string userId, double latitude, double longitude, int distance)
        {
            var settings = new ConnectionSettings(new Uri("http://localhost:9200"), "mapnotes");
            var client = new ElasticClient(settings);

            var result = client.Search<NoteIndex>(s => s
                .Take(9999)
                .Index("mapnotes")
                .Query(q => q.Match(m => m.OnField(f => f.UserId).Query(userId)))
                .Filter(f => f.GeoDistance(l => l.Location, d => d.Distance(distance, GeoUnit.Kilometers)
                                    .Location(latitude, longitude)
                                    .Optimize(GeoOptimizeBBox.Indexed))));

            var notes = result.Documents.Select(x => new NearestNoteModel
            {
                Title = x.Title,
                Latitude = x.Location.Lat,
                Longitude = x.Location.Lon
            });

            return notes;
        }
開發者ID:motivks,項目名稱:map-notes,代碼行數:22,代碼來源:NoteManager.cs


注:本文中的Nest.ElasticClient.Search方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。