- .NET Clients: other versions:
- Introduction
- Installation
- Breaking changes
- API Conventions
- Elasticsearch.Net - Low level client
- NEST - High level client
- Troubleshooting
- Search
- Query DSL
- Full text queries
- Term level queries
- Exists Query Usage
- Fuzzy Date Query Usage
- Fuzzy Numeric Query Usage
- Fuzzy Query Usage
- Ids Query Usage
- Prefix Query Usage
- Date Range Query Usage
- Long Range Query Usage
- Numeric Range Query Usage
- Term Range Query Usage
- Regexp Query Usage
- Term Query Usage
- Terms Set Query Usage
- Terms List Query Usage
- Terms Lookup Query Usage
- Terms Query Usage
- Wildcard Query Usage
- Compound queries
- Joining queries
- Geo queries
- Specialized queries
- Span queries
- NEST specific queries
- Aggregations
- Metric Aggregations
- Average Aggregation Usage
- Boxplot Aggregation Usage
- Cardinality Aggregation Usage
- Extended Stats Aggregation Usage
- Geo Bounds Aggregation Usage
- Geo Centroid Aggregation Usage
- Geo Line Aggregation Usage
- Max Aggregation Usage
- Median Absolute Deviation Aggregation Usage
- Min Aggregation Usage
- Percentile Ranks Aggregation Usage
- Percentiles Aggregation Usage
- Rate Aggregation Usage
- Scripted Metric Aggregation Usage
- Stats Aggregation Usage
- String Stats Aggregation Usage
- Sum Aggregation Usage
- T Test Aggregation Usage
- Top Hits Aggregation Usage
- Top Metrics Aggregation Usage
- Value Count Aggregation Usage
- Weighted Average Aggregation Usage
- Bucket Aggregations
- Adjacency Matrix Usage
- Auto Date Histogram Aggregation Usage
- Children Aggregation Usage
- Composite Aggregation Usage
- Date Histogram Aggregation Usage
- Date Range Aggregation Usage
- Diversified Sampler Aggregation Usage
- Filter Aggregation Usage
- Filters Aggregation Usage
- Geo Distance Aggregation Usage
- Geo Hash Grid Aggregation Usage
- Geo Tile Grid Aggregation Usage
- Global Aggregation Usage
- Histogram Aggregation Usage
- Ip Range Aggregation Usage
- Missing Aggregation Usage
- Multi Terms Aggregation Usage
- Nested Aggregation Usage
- Parent Aggregation Usage
- Range Aggregation Usage
- Rare Terms Aggregation Usage
- Reverse Nested Aggregation Usage
- Sampler Aggregation Usage
- Significant Terms Aggregation Usage
- Significant Text Aggregation Usage
- Terms Aggregation Usage
- Variable Width Histogram Usage
- Pipeline Aggregations
- Average Bucket Aggregation Usage
- Bucket Script Aggregation Usage
- Bucket Selector Aggregation Usage
- Bucket Sort Aggregation Usage
- Cumulative Cardinality Aggregation Usage
- Cumulative Sum Aggregation Usage
- Derivative Aggregation Usage
- Extended Stats Bucket Aggregation Usage
- Max Bucket Aggregation Usage
- Min Bucket Aggregation Usage
- Moving Average Ewma Aggregation Usage
- Moving Average Holt Linear Aggregation Usage
- Moving Average Holt Winters Aggregation Usage
- Moving Average Linear Aggregation Usage
- Moving Average Simple Aggregation Usage
- Moving Function Aggregation Usage
- Moving Percentiles Aggregation Usage
- Normalize Aggregation Usage
- Percentiles Bucket Aggregation Usage
- Serial Differencing Aggregation Usage
- Stats Bucket Aggregation Usage
- Sum Bucket Aggregation Usage
- Matrix Aggregations
- Metric Aggregations
Document paths
editDocument paths
editMany APIs in Elasticsearch describe a path to a document. In NEST, besides generating a constructor that takes
an Index and Id separately, we also generate a constructor that allows you to describe the path
to your document more succinctly using a an instance of the DocumentPath<T>
type.
Creating new instances
edithere we create a new document path based on Project with the id 1
IDocumentPath path = new DocumentPath<Project>(1); Expect("project").WhenSerializing(path.Index); Expect(1).WhenSerializing(path.Id);
You can still override the inferred index name
path = new DocumentPath<Project>(1).Index("project1"); Expect("project1").WhenSerializing(path.Index);
and there is also a static way to describe such paths
path = DocumentPath<Project>.Id(1); Expect("project").WhenSerializing(path.Index); Expect(1).WhenSerializing(path.Id);
Creating from a document type instance
editif you have an instance of your document you can use it as well generate document paths
var project = new Project { Name = "hello-world" };
here we create a new document path based on the instance of Project
, project
IDocumentPath path = new DocumentPath<Project>(project); Expect("project").WhenSerializing(path.Index); Expect("hello-world").WhenSerializing(path.Id);
You can still override the inferred index name
path = new DocumentPath<Project>(project).Index("project1"); Expect("project1").WhenSerializing(path.Index);
and again, there is also a static way to describe such paths
path = DocumentPath<Project>.Id(project); Expect("project").WhenSerializing(path.Index); DocumentPath<Project> p = project;
An example with requests
editvar project = new Project { Name = "hello-world" };
we can see an example of how DocumentPath
helps your describe your requests more tersely
var request = new IndexRequest<Project>(2) { Document = project }; request = new IndexRequest<Project>(project);
when comparing with the full blown constructor and passing document manually,
DocumentPath<T>
's benefits become apparent. Compare the following request that doesn’t
use DocumentPath<T>
with the former examples
request = new IndexRequest<Project>(IndexName.From<Project>(), 2) { Document = project };
Much more verbose, wouldn’t you agree?