What is a Document Query?
-
Queries in RavenDB can be written using
Query
,DocumentQuery
or directly withRQL
.
Learn more in Query Overview. -
Unlike the
Query
method, theDocumentQuery
method does Not support LINQ.
However, it gives you more flexibility and control over the process of building a query,
as it provides low-level querying capabilities. See Query -vs- DocumentQuery for all differences. -
In this page:
DocumentQuery examples
Query collection - no filtering
// Query for all documents from 'Employees' collection
List<Employee> allEmployees = session.Advanced
.DocumentQuery<Employee>()
.ToList();
// Query for all documents from 'Employees' collection
List<Employee> allEmployees = await asyncSession.Advanced
.AsyncDocumentQuery<Employee>()
.ToListAsync();
from "Employees"
Query collection - by ID
// Query collection by document ID
Employee employee = session.Advanced
.DocumentQuery<Employee>()
.WhereEquals(x => x.Id, "employees/1-A")
.FirstOrDefault();
// Query collection by document ID
Employee employee = await asyncSession.Advanced
.AsyncDocumentQuery<Employee>()
.WhereEquals(x => x.Id, "employees/1-A")
.FirstOrDefaultAsync();
from "Employees" where id() == "employees/1-A"
Query collection - with filtering
// Query collection - filter by document field
List<Employee> employees = session.Advanced
.DocumentQuery<Employee>()
.WhereEquals(x => x.FirstName, "Robert")
.ToList();
// Query collection - filter by document field
List<Employee> employees = await asyncSession.Advanced
.AsyncDocumentQuery<Employee>()
.WhereEquals(x => x.FirstName, "Robert")
.ToListAsync();
from "Employees" where FirstName == "Robert"
Query collection - with paging
// Query collection - page results
List<Product> products = session.Advanced
.DocumentQuery<Product>()
.Skip(5) // Skip first 5 results
.Take(10) // Load up to 10 entities from 'Products' collection
.ToList();
// Query collection - page results
List<Product> products = await asyncSession.Advanced
.AsyncDocumentQuery<Product>()
.Skip(5) // Skip first 5 results
.Take(10) // Load up to 10 entities from 'Products' collection
.ToListAsync();
from "Products" limit 5, 10 // skip 5, take 10
Query an index
- Please refer to Querying an index for examples of querying an index using a DocumentQuery.
Convert between DocumentQuery and Query
DocumentQuery to Query
- A
DocumentQuery
can be converted to aQuery
.
This enables you to take advantage of all available LINQ extensions provided by RavenDB.
// Define a DocumentQuery
var docQuery = session.Advanced
.DocumentQuery<Order>(); // 'IDocumentQuery' instance
// Convert to Query
var query = docQuery.ToQueryable(); // 'IRavenQueryable' instance
// Apply any 'IRavenQueryable' LINQ extension
var queryResults = query
.Where(x => x.Freight > 25)
.ToList();
// Define a DocumentQuery
var docQuery = asyncSession.Advanced
.AsyncDocumentQuery<Order>(); // 'IAsyncDocumentQuery' instance
// Convert to Query
var query = docQuery.ToQueryable(); // 'IRavenQueryable' instance
// Apply any 'IRavenQueryable' LINQ extension
var queryResults = await query
.Where(x => x.Freight > 25)
.ToListAsync();
from "Orders" where Freight > 25
- Convert
DocumentQuery
toQuery
when you need to project data from a related document
in a dynamic query.
// Define a DocumentQuery
var docQuery = session.Advanced
.DocumentQuery<Order>()
.WhereGreaterThan("Freight", 25);
// Convert to Query
var query = docQuery.ToQueryable();
// Define the projection on the query using LINQ
var projectedQuery = from order in query
// Load the related document
let company = session.Load<Company>(order.Company)
// Define the projection
select new
{
Freight = order.Freight, // data from the Order document
CompanyName = company.Name // data from the related Company document
};
// Execute the query
var queryResults = projectedQuery.ToList();
from "Orders" as o
where o.Freight > 25
load o.Company as c
select {
Freight: o.Freight,
CompanyName: c.Name
}
Query to DocumentQuery
- A
Query
can be converted to aDocumentQuery
.
This enables you to take advantage of the API available only for DocumentQuery.
// Define a Query
var query = session
.Query<Order>()
.Where(x => x.Freight > 25);
// Convert to DocumentQuery
var docQuery = query.ToDocumentQuery();
// Apply a DocumentQuery method (e.g. IncludeExplanations is Not available on Query)
docQuery.IncludeExplanations(out Explanations exp);
// Execute the query
var docQueryResults = docQuery.ToList();
// Define a Query
var query = asyncSession
.Query<Order>()
.Where(x => x.Freight > 25);
// Convert to DocumentQuery
var docQuery = query.ToAsyncDocumentQuery();
// Apply a DocumentQuery method (e.g. IncludeExplanations is Not available on Query)
docQuery.IncludeExplanations(out Explanations exp);
// Execute the query
var docQueryResults = docQuery.ToListAsync();
from "Orders"
where Freight > 25
include explanations()
Custom Methods and Extensions
Several methods share the same functionality as their Query
counterparts.
Refer to the corresponding documentation articles, marked with links starting with "[Query]" in the list below.
Available custom methods and extensions:
- AddOrder
- [Query] AfterQueryExecuted
- [Query] AfterStreamExecuted
- [Query] AggregateBy
- [Query] AggregateUsing
- AndAlso
- [Query] BeforeQueryExecuted
- Boost
- CloseSubclause
- CmpXchg
- ContainsAll
- ContainsAny
- Count
- CountLazily
- Distinct
- ExplainScores
- First
- FirstOrDefault
- Fuzzy
- GetIndexQuery
- GetQueryResult
- GroupBy
- GroupByArrayValues
- GroupByArrayContent
- [Query] Highlight
- Include
- IncludeExplanations
- Intersect
- InvokeAfterQueryExecuted
- InvokeAfterStreamExecuted
- [Query] Lazily
- LongCount
- MoreLikeThis
- NegateNext
- Not
- [Query] NoCaching
- [Query] NoTracking
- OfType
- OpenSubclause
- OrderBy
- OrderByDescending
- [Query] OrderByDistance
- [Query] OrderByDistanceDescending
- OrderByScore
- OrderByScoreDescending
- OrElse
- [Query] Projection
- Proximity
- [Query] RandomOrdering
- [Query] RelatesToShape
- Search
- SelectFields
- SelectTimeSeries
- Single
- SingleOrDefault
- Skip
- [Query] Spatial
- Statistics
- SuggestUsing
- Take
- [Query] Timings
- UsingDefaultOperator
- [Query] WaitForNonStaleResults
- Where
- WhereBetween
- WhereEndsWith
- WhereEquals
- WhereExists
- WhereGreaterThan
- WhereGreaterThanOrEqual
- WhereIn
- WhereLessThan
- WhereLessThanOrEqual
- WhereLucene
- WhereNotEquals
- WhereRegex
- WhereStartsWith
- WithinRadiusOf
Syntax
The available DocumentQuery
overloads are listed in this Syntax section in the Query Overview.