当前位置: 首页>>代码示例>>C#>>正文


C# Data.IndexQuery类代码示例

本文整理汇总了C#中Raven.Abstractions.Data.IndexQuery的典型用法代码示例。如果您正苦于以下问题:C# IndexQuery类的具体用法?C# IndexQuery怎么用?C# IndexQuery使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


IndexQuery类属于Raven.Abstractions.Data命名空间,在下文中一共展示了IndexQuery类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: BuildQuery

		public static Query BuildQuery(string query, IndexQuery indexQuery, PerFieldAnalyzerWrapper analyzer)
		{
			var originalQuery = query;
			Analyzer keywordAnalyzer = new KeywordAnalyzer();
			try
			{
				var queryParser = new RangeQueryParser(Version.LUCENE_29, indexQuery.DefaultField ?? string.Empty, analyzer)
				{
					DefaultOperator = indexQuery.DefaultOperator == QueryOperator.Or
										? QueryParser.Operator.OR
										: QueryParser.Operator.AND,
					AllowLeadingWildcard = true
				};
				query = PreProcessUntokenizedTerms(query, queryParser);
				query = PreProcessSearchTerms(query);
				query = PreProcessDateTerms(query, queryParser);
				var generatedQuery = queryParser.Parse(query);
				generatedQuery = HandleMethods(generatedQuery);
				return generatedQuery;
			}
			catch (ParseException pe)
			{
				if (originalQuery == query)
					throw new ParseException("Could not parse: '" + query + "'", pe);
				throw new ParseException("Could not parse modified query: '" + query + "' original was: '" + originalQuery + "'", pe);

			}
			finally
			{
				keywordAnalyzer.Close();
			}
		}
开发者ID:shiranGinige,项目名称:ravendb,代码行数:32,代码来源:QueryBuilder.cs

示例2: GetRevisionsRequiringActivation

        public static IList<string> GetRevisionsRequiringActivation(DocumentDatabase database)
        {
            var currentTime = SystemTime.UtcNow;
            database.WaitForIndexToBecomeNonStale(TemporalConstants.PendingRevisionsIndex, currentTime, null);

            const int pageSize = 1024;

            var qs = string.Format("{0}:[* TO {1:o}]", Activation, currentTime);

            var query = new IndexQuery {
                                           Start = 0,
                                           PageSize = pageSize,
                                           Cutoff = currentTime,
                                           Query = qs,
                                           FieldsToFetch = new[] { Constants.DocumentIdFieldName },
                                           SortedFields = new[] { new SortedField(Activation) }
                                       };

            var list = new List<string>();
            while (true)
            {
                var results = database.Query(TemporalConstants.PendingRevisionsIndex, query).Results;
                list.AddRange(results.Select(x => x.Value<string>(Constants.DocumentIdFieldName)));
                if (results.Count < pageSize)
                    return list;
                query.Start += pageSize;
            }
        }
开发者ID:jggutierrez,项目名称:RavenDB-TemporalVersioning,代码行数:28,代码来源:PendingRevisionsIndex.cs

示例3: SpatialIndexQuery

 /// <summary>
 /// Initializes a new instance of the <see cref="SpatialIndexQuery"/> class.
 /// </summary>
 /// <param name="query">The query.</param>
 public SpatialIndexQuery(IndexQuery query) : this()
 {
     Query = query.Query;
     Start = query.Start;
     Cutoff = query.Cutoff;
     WaitForNonStaleResultsAsOfNow = query.WaitForNonStaleResultsAsOfNow;
     CutoffEtag = query.CutoffEtag;
     PageSize = query.PageSize;
     FieldsToFetch = query.FieldsToFetch;
     DefaultField = query.DefaultField; // keep?
     DefaultOperator = query.DefaultOperator;
     SortedFields = query.SortedFields;
     HighlightedFields = query.HighlightedFields;
     HighlighterPreTags = query.HighlighterPreTags;
     HighlighterPostTags = query.HighlighterPostTags;
     HighlighterKeyName = query.HighlighterKeyName;
     ResultsTransformer = query.ResultsTransformer;
     TransformerParameters = query.TransformerParameters;
     ExplainScores = query.ExplainScores;
     SortHints = query.SortHints;
     IsDistinct = query.IsDistinct;
     AllowMultipleIndexEntriesForSameDocumentToResultTransformer =
         query.AllowMultipleIndexEntriesForSameDocumentToResultTransformer;
     
 }
开发者ID:j2jensen,项目名称:ravendb,代码行数:29,代码来源:SpatialIndexQuery.cs

示例4: RestartNotCompletedOperations

        public void RestartNotCompletedOperations()
        {
            var lastEtag = db.GetLastEtag();
            db.WaitForIndexNotStale(UpdateCascadeOperation.ByStatusIndexName, null, lastEtag, TimeSpan.FromHours(1), CancellationToken.None);
            var indexQuery = new IndexQuery
            {
                CutoffEtag = lastEtag,
                PageSize = 1024,
                Query = "Status:Pending OR Status:Executing"
            };
            IList<string> docIds = null;
            int restartedOperations = 0;
            do
            {
                docIds = db.QueryDocumentIds(UpdateCascadeOperation.ByStatusIndexName, indexQuery, CancellationToken.None);
                indexQuery.Start += docIds.Count;
                db.TransactionalStorage.Batch(_ =>
                {
                    foreach (var id in docIds)
                    {
                        var operation = repository.Get(id);
                        JsonDocument referenceDocument = null;
                        if (operation != null) referenceDocument = db.Get(operation.ReferencedDocId, null);

                        if (operation != null && referenceDocument != null && TryStartOperation(operation, referenceDocument))
                        {
                            restartedOperations++;
                            log.Debug("Operation {0} has been restarted after a reboot. {1} operations restarted so far", id, restartedOperations);
                        }
                    }
                });

            } while (docIds.Count == indexQuery.PageSize);
        }
开发者ID:jesuslpm,项目名称:UpdateCascadeBundle,代码行数:34,代码来源:UpdateCascadeOperationsCoordinator.cs

示例5: HandleTermsFacet

		private void HandleTermsFacet(string index, Facet facet, IndexQuery indexQuery, IndexSearcher currentIndexSearcher, Dictionary<string, IEnumerable<FacetValue>> results)
		{
			var terms = database.ExecuteGetTermsQuery(index,
													  facet.Name, null,
													  database.Configuration.MaxPageSize);
			var termResults = new List<FacetValue>();
			var baseQuery = database.IndexStorage.GetLuceneQuery(index, indexQuery, database.IndexQueryTriggers);
			foreach (var term in terms)
			{
				var termQuery = new TermQuery(new Term(facet.Name, term));

				var joinedQuery = new BooleanQuery();
				joinedQuery.Add(baseQuery, BooleanClause.Occur.MUST);
				joinedQuery.Add(termQuery, BooleanClause.Occur.MUST);

				var topDocs = currentIndexSearcher.Search(joinedQuery, null, 1);

				if (topDocs.TotalHits > 0)
				{
					termResults.Add(new FacetValue
					{
						Count = topDocs.TotalHits,
						Range = term
					});
				}
			}

			results[facet.Name] = termResults;
		}
开发者ID:neiz,项目名称:ravendb,代码行数:29,代码来源:FacetedQueryRunner.cs

示例6: ShouldWork

		public void ShouldWork()
		{
			using (var store = NewDocumentStore(requestedStorage: "voron"))
			{
				using (var bulkInsert = store.BulkInsert())
				{
					for (int i = 0; i < 20000; i++)
					{
						bulkInsert.Store(new User { Id = i.ToString(), Name = "Name" + i });
					}
				}

				WaitForIndexing(store);
				var queryToDelete = new IndexQuery
				                    {
					                    Query = "Tag:Users"
				                    };

				var operation = store.DatabaseCommands.DeleteByIndex("Raven/DocumentsByEntityName", queryToDelete);
				operation.WaitForCompletion();

				using (var session = store.OpenSession())
				{
					var count = session
						.Query<User>("Raven/DocumentsByEntityName")
						.Customize(x => x.WaitForNonStaleResults())
						.Count();

					Assert.Equal(0, count);
				}
			}
		}
开发者ID:WimVergouwe,项目名称:ravendb,代码行数:32,代码来源:RavenDB_2134.cs

示例7: GetFacets

        public FacetResults GetFacets(string index, IndexQuery indexQuery, List<Facet> facets, int start = 0, int? pageSize = null)
        {
            var sp = Stopwatch.StartNew();
            var results = new FacetResults();
            var defaultFacets = new Dictionary<string, Facet>();
            var rangeFacets = new Dictionary<string, List<ParsedRange>>();

            var viewGenerator = database.IndexDefinitionStorage.GetViewGenerator(index);
            Index.AssertQueryDoesNotContainFieldsThatAreNotIndexed(indexQuery, viewGenerator);

            foreach (var facet in facets)
            {
                var key = string.IsNullOrWhiteSpace(facet.DisplayName) ? facet.Name : facet.DisplayName;

                defaultFacets[key] = facet;
                if (facet.Aggregation != FacetAggregation.Count && facet.Aggregation != FacetAggregation.None)
                {
                    if (string.IsNullOrEmpty(facet.AggregationField))
                        throw new InvalidOperationException("Facet " + facet.Name + " cannot have aggregation set to " +
                                                            facet.Aggregation + " without having a value in AggregationField");

                    if (string.IsNullOrEmpty(facet.AggregationType))
                        throw new InvalidOperationException("Facet " + facet.Name + " cannot have aggregation set to " +
                                                            facet.Aggregation + " without having a value in AggregationType");

                    if (facet.AggregationField.EndsWith("_Range") == false)
                    {
                        if( QueryForFacets.IsAggregationTypeNumerical(facet.AggregationType))
                             facet.AggregationField = facet.AggregationField + "_Range";
                    }
                       
                }


                switch (facet.Mode)
                {
                    case FacetMode.Default:
                        results.Results[key] = new FacetResult();
                        break;
                    case FacetMode.Ranges:
                        rangeFacets[key] = facet.Ranges.Select(range => ParseRange(facet.Name, range)).ToList();
                        results.Results[key] = new FacetResult
                        {
                            Values = facet.Ranges.Select(range => new FacetValue
                            {
                                Range = range,
                            }).ToList()
                        };

                        break;
                    default:
                        throw new ArgumentException(string.Format("Could not understand '{0}'", facet.Mode));
                }
            }

            var queryForFacets = new QueryForFacets(database, index, defaultFacets, rangeFacets, indexQuery, results, start, pageSize);
            queryForFacets.Execute();
            results.Duration = sp.Elapsed;
            return results;
        }
开发者ID:bbqchickenrobot,项目名称:ravendb,代码行数:60,代码来源:FacetedQueryRunner.cs

示例8: GetFieldsInternal

		private static HashSet<string> GetFieldsInternal(IndexQuery query, Regex queryTerms)
		{
			var fields = new HashSet<string>();
			if (string.IsNullOrEmpty(query.DefaultField) == false)
			{
				fields.Add(query.DefaultField);
			}
			if(query.Query == null)
				return fields;
			var dates = dateQuery.Matches(query.Query); // we need to exclude dates from this check
			var queryTermMatches = queryTerms.Matches(query.Query);
			for (int x = 0; x < queryTermMatches.Count; x++)
			{
				Match match = queryTermMatches[x];
				String field = match.Groups[1].Value;

				var isDate = false;
				for (int i = 0; i < dates.Count; i++)
				{
					if(match.Index < dates[i].Index)
						continue;
					if (match.Index >= dates[i].Index + dates[i].Length) 
						continue;

					isDate = true;
					break;
				}

				if (isDate == false)
				fields.Add(field);
			}
			return fields;
		}
开发者ID:royra,项目名称:ravendb,代码行数:33,代码来源:SimpleQueryParser.cs

示例9: LazyFacetsOperation

		public LazyFacetsOperation( string index, string facetSetupDoc, IndexQuery query, int start = 0, int? pageSize = null ) {
			this.index = index;
			this.facetSetupDoc = facetSetupDoc;
			this.query = query;
			this.start = start;
			this.pageSize = pageSize;
		}
开发者ID:WimVergouwe,项目名称:ravendb,代码行数:7,代码来源:LazyFacetsOperation.cs

示例10: OnDelete

        /// <summary>
        /// Called when [delete].
        /// </summary>
        /// <param name="key">The key.</param>
        /// <param name="transactionInformation">The transaction information.</param>
        public override void OnDelete(string key, TransactionInformation transactionInformation)
        {
            if (key.StartsWith("Raven/")) // we don't deal with system documents
                return;

            var childrenQuery = new IndexQuery
            {
                Query = "Id:" + key
            };

            var queryResult = Database.Query("Documents/ByParent", childrenQuery);

            if (queryResult.Results.Count > 0) {
                foreach (var result in queryResult.Results) {

                    var metadataJObject = result.Value<RavenJObject>("@metadata");

                    if (metadataJObject != null)
                    {
                        var childId = metadataJObject.Value<string>("@id");

                        var childEtag = metadataJObject.Value<string>("@etag");
                        Database.Delete(childId, Guid.Parse(childEtag), transactionInformation);
                    }
                }
            }

            base.OnDelete(key, transactionInformation);
        }
开发者ID:dasheddot,项目名称:BrickPile,代码行数:34,代码来源:DeleteTrigger.cs

示例11: DoInResults

        protected void DoInResults(
            Action<RavenJObject> action, 
            string query = "*:*", 
            int pageSize = 64, 
            string index = "Dynamic", 
            string[] includes = null)
        {
            int start = 0;
            while (true)
            {
                var qry = new IndexQuery()
                {
                    Query = query,
                    PageSize = pageSize,
                    Start = start //TODO: consider to use another thing in place of start
                };

                var results = DocumentStore.DatabaseCommands.Query(index, qry, includes);

                if (results.Results.Count == 0)
                    break;

                foreach (var result in results.Results)
                    action(result);

                start += pageSize;
            }
        }
开发者ID:newaccount978,项目名称:CommonJobs,代码行数:28,代码来源:Migration.cs

示例12: GetIndexQueryFromHttpContext

		public static IndexQuery GetIndexQueryFromHttpContext(this IHttpContext context, int maxPageSize)
		{
			var query = new IndexQuery
			{
				Query = context.Request.QueryString["query"] ?? "",
				Start = context.GetStart(),
				Cutoff = context.GetCutOff(),
				CutoffEtag = context.GetCutOffEtag(),
				PageSize = context.GetPageSize(maxPageSize),
				SkipTransformResults = context.GetSkipTransformResults(),
				FieldsToFetch = context.Request.QueryString.GetValues("fetch"),
				GroupBy = context.Request.QueryString.GetValues("groupBy"),
				AggregationOperation = context.GetAggregationOperation(),
				SortedFields = context.Request.QueryString.GetValues("sort")
					.EmptyIfNull()
					.Select(x => new SortedField(x))
					.ToArray()
			};

			double lat = context.GetLat(), lng = context.GetLng(), radius = context.GetRadius();
			if (lat != 0 || lng != 0 || radius != 0)
			{
				return new SpatialIndexQuery(query)
				{
					Latitude = lat,
					Longitude = lng,
					Radius = radius,
				};
			}
			return query;
		}
开发者ID:nhsevidence,项目名称:ravendb,代码行数:31,代码来源:HttpContextExtensions.cs

示例13: HandleRangeFacet

		private void HandleRangeFacet(string index, Facet facet, IndexQuery indexQuery, IndexSearcher currentIndexSearcher, Dictionary<string, IEnumerable<FacetValue>> results)
		{
			var rangeResults = new List<FacetValue>();
			foreach (var range in facet.Ranges)
			{
				var baseQuery = database.IndexStorage.GetLuceneQuery(index, indexQuery, database.IndexQueryTriggers);
				//TODO the built-in parser can't handle [NULL TO 100.0}, i.e. a mix of [ and }
				//so we need to handle this ourselves (greater and less-than-or-equal)
				var rangeQuery = database.IndexStorage.GetLuceneQuery(index, new IndexQuery
				{
					Query = facet.Name + ":" + range
				}, database.IndexQueryTriggers);

				var joinedQuery = new BooleanQuery();
				joinedQuery.Add(baseQuery, BooleanClause.Occur.MUST);
				joinedQuery.Add(rangeQuery, BooleanClause.Occur.MUST);

				var topDocs = currentIndexSearcher.Search(joinedQuery, null, 1);

				if (topDocs.TotalHits > 0)
				{
					rangeResults.Add(new FacetValue
					{
						Count = topDocs.TotalHits,
						Range = range
					});
				}
			}

			results[facet.Name] = rangeResults;
		}
开发者ID:neiz,项目名称:ravendb,代码行数:31,代码来源:FacetedQueryRunner.cs

示例14: GetFacets

		public IDictionary<string, IEnumerable<FacetValue>> GetFacets(string index, IndexQuery indexQuery, string facetSetupDoc)
		{
			var facetSetup = database.Get(facetSetupDoc, null);
			if (facetSetup == null)
				throw new InvalidOperationException("Could not find facets document: " + facetSetupDoc);

			var facets = facetSetup.DataAsJson.JsonDeserialization<FacetSetup>().Facets;

			var results = new Dictionary<string, IEnumerable<FacetValue>>();

			IndexSearcher currentIndexSearcher;
			using (database.IndexStorage.GetCurrentIndexSearcher(index, out currentIndexSearcher))
			{
				foreach (var facet in facets)
				{
					switch (facet.Mode)
					{
						case FacetMode.Default:
							HandleTermsFacet(index, facet, indexQuery, currentIndexSearcher, results);
							break;
						case FacetMode.Ranges:
							HandleRangeFacet(index, facet, indexQuery, currentIndexSearcher, results);
							break;
						default:
							throw new ArgumentException(string.Format("Could not understand '{0}'", facet.Mode));
					}
				}

			}

			return results;
		}
开发者ID:neiz,项目名称:ravendb,代码行数:32,代码来源:FacetedQueryRunner.cs

示例15: FromQueryString

        public static IndexQuery FromQueryString(string queryString)
        {
            var fields = queryString.Split(new[] {'&'}, StringSplitOptions.RemoveEmptyEntries)
                .Select(segment =>
                            {
                                var parts = segment.Split(new[] {'='}, StringSplitOptions.RemoveEmptyEntries);
                                if (parts.Length == 1)
                                {
                                    return new {Key = parts[0], Value = string.Empty};
                                }
                                else
                                {
                                    return
                                        new
                                            {
                                                Key = parts[0],
                                                Value = Uri.UnescapeDataString(parts[1])
                                            };
                                }
                            }).ToLookup(f => f.Key, f => f.Value);

            var query = new IndexQuery
            {
                Query = Uri.UnescapeDataString(fields["query"].FirstOrDefault() ?? ""),
                Start = fields.GetStart(),
                Cutoff = fields.GetCutOff(),
                CutoffEtag = fields.GetCutOffEtag(),
                PageSize = fields.GetPageSize(250),
                SkipTransformResults = fields.GetSkipTransformResults(),
                FieldsToFetch = fields["fetch"].ToArray(),
                GroupBy = fields["groupBy"].ToArray(),
                AggregationOperation = fields.GetAggregationOperation(),
                SortedFields = fields["sort"]
                    .EmptyIfNull()
                    .Select(x => new SortedField(x))
                    .ToArray(),
                SortByAggregation = SortFieldAggregation.Default
            };

            SortFieldAggregation sortFieldAggregation;
            var sortAggregationQuerystringValue = fields["sortAggregation"].FirstOrDefault();
            if (!string.IsNullOrEmpty(sortAggregationQuerystringValue) &&
                SortFieldAggregation.TryParse(sortAggregationQuerystringValue, out sortFieldAggregation))
            {
                query.SortByAggregation = sortFieldAggregation;
            }

            double lat = fields.GetLat(), lng = fields.GetLng(), radius = fields.GetRadius();
            if (lat != 0 || lng != 0 || radius != 0)
            {
                return new SpatialIndexQuery(query)
                {
					QueryShape = SpatialIndexQuery.GetQueryShapeFromLatLon(lat, lng, radius),
                    SpatialRelation = SpatialRelation.Within, /* TODO */
					SpatialFieldName = Constants.DefaultSpatialFieldName, /* TODO */
                };
            }
            return query;
        }
开发者ID:fschwiet,项目名称:ravendb,代码行数:59,代码来源:IndexQueryHelpers.cs


注:本文中的Raven.Abstractions.Data.IndexQuery类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。