- HTTP request
- Path parameters
- Request body
- Response body
- Authorization scopes
- QueryResultBatch
- ResultType
- Try it!
Queries for entities.
HTTP request
POST https://datastore.googleapis.com/v1/projects/{projectId}:runQuery
The URL uses gRPC Transcoding syntax.
Path parameters
| Parameters | |
|---|---|
| projectId | 
 Required. The ID of the project against which to make the request. | 
Request body
The request body contains data with the following structure:
| JSON representation | 
|---|
| { "databaseId": string, "partitionId": { object ( | 
| Fields | |
|---|---|
| databaseId | 
 The ID of the database against which to make the request. '(default)' is not allowed; please use empty string '' to refer the default database. | 
| partitionId | 
 Entities are partitioned into subsets, identified by a partition ID. Queries are scoped to a single partition. This partition ID is normalized with the standard default context partition ID. | 
| readOptions | 
 The options for this query. | 
| propertyMask | 
 The properties to return. This field must not be set for a projection query. | 
| explainOptions | 
 Optional. Explain options for the query. If set, additional query statistics will be returned. If not, only query results will be returned. | 
| Union field query_type. The type of query.query_typecan be only one of the following: | |
| query | 
 The query to run. | 
| gqlQuery | 
 The GQL query to run. This query must be a non-aggregation query. | 
Response body
The response for Datastore.RunQuery.
If successful, the response body contains data with the following structure:
| JSON representation | 
|---|
| { "batch": { object ( | 
| Fields | |
|---|---|
| batch | 
 A batch of query results. This is always present unless running a query under explain-only mode:  | 
| query | 
 The parsed form of the  | 
| transaction | 
 The identifier of the transaction that was started as part of this projects.runQuery request. Set only when  A base64-encoded string. | 
| explainMetrics | 
 Query explain metrics. This is only present when the  | 
Authorization scopes
Requires one of the following OAuth scopes:
- https://www.googleapis.com/auth/datastore
- https://www.googleapis.com/auth/cloud-platform
For more information, see the Authentication Overview.
QueryResultBatch
A batch of results produced by a query.
| JSON representation | 
|---|
| { "skippedResults": integer, "skippedCursor": string, "entityResultType": enum ( | 
| Fields | |
|---|---|
| skippedResults | 
 The number of results skipped, typically because of an offset. | 
| skippedCursor | 
 A cursor that points to the position after the last skipped result. Will be set when  A base64-encoded string. | 
| entityResultType | 
 The result type for every entity in  | 
| entityResults[] | 
 The results for this batch. | 
| endCursor | 
 A cursor that points to the position after the last result in the batch. A base64-encoded string. | 
| moreResults | 
 The state of the query after the current batch. | 
| snapshotVersion | 
 The version number of the snapshot this batch was returned from. This applies to the range of results from the query's  In a single transaction, subsequent query result batches for the same query can have a greater snapshot version number. Each batch's snapshot version is valid for all preceding batches. The value will be zero for eventually consistent queries. | 
| readTime | 
 Read timestamp this batch was returned from. This applies to the range of results from the query's  In a single transaction, subsequent query result batches for the same query can have a greater timestamp. Each batch's read timestamp is valid for all preceding batches. This value will not be set for eventually consistent queries in Cloud Datastore. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
ResultType
Specifies what data the 'entity' field contains. A ResultType is either implied (for example, in LookupResponse.missing from datastore.proto, it is always KEY_ONLY) or specified by context (for example, in message QueryResultBatch, field entityResultType specifies a ResultType for all the values in field entityResults).
| Enums | |
|---|---|
| RESULT_TYPE_UNSPECIFIED | Unspecified. This value is never used. | 
| FULL | The key and properties. | 
| PROJECTION | A projected subset of properties. The entity may have no key. | 
| KEY_ONLY | Only the key. |