Location-based queries
This topic explains how to create requests for basic location-based information using the Retrieve Data operation.
Example requests are POSTed to the Retrieve Data URL:
https://<<hostName>>/api/v1/commons/data/multi_read
Retrieve Data operations aggregate data from across the suite using the Data Dictionary data elements defined in the request. Each response provides metadata that allows for caching and paging, which is covered in detail in the Cache, count, and index topic.
Prerequisites
Understand the concepts covered in the following topics:
Example request
In this location-based example, the request:
- selects location names and addresses from
parameterized
data elements using Data Dictionary keys and properties - defines the data view as ORGANIZATION, which is similar to a Business Structure Dataview
- specifies a set of locations using location IDs
- establishes a date range for the requested data in the form of start and end dates and times
{
"select": [
{
"key": "LOCATION_NAME",
"properties": [
{
"key": "15"
}
]
},
{
"key": "LOCATION_ADDRESS",
"properties": [
{
"key": "15"
}
]
}
],
"from": {
"view": "ORGANIZATION",
"locationSet": {
"locations": {
"qualifiers": [
"Organization/United States/Metropolitan Plant/Machine Shop/Machine Shop 256"
]
},
"dateRange": {
"startDate": "2019-01-01T00:00:00.000",
"endDate": "2019-01-09T00:00:00.000"
}
}
}
}
Notes of interest
- In this example, the
key
withinproperties
must match the location'stype
in order to display the selected node's name and address. The name and address of an ancestor node can be displayed by changing thekey
to a value that matches the type of the desired ancestor. - Refer to the Resource Details of the Retrieve Data POST
/v1/commons/data/multi_read
operation for descriptions of each object, array, and property.
Example response
The request defined a set of locations and retrieved their names and addresses using the parameterized
Data Dictionary keys LOCATION_NAME
and LOCATION_ADDRESS
.
{
"metadata": {
"lastRefreshed": null,
"cacheExpirationTime": null,
"numNodes": "3",
"metadataKey": "7c082a3e-fc40-4adc-a6e8-40743766a14e",
"cacheKey": "cab78a88-79d2-4320-b7a8-1c35f75c70d3",
"totalNodes": "3",
"totalElements": "3"
},
"data": {
"key": {
"ROOT": "-1"
},
"coreEntityKey": {},
"attributes": [],
"children": [
{
"key": {
"LOCATION": "2001"
},
"coreEntityKey": {
"ORG": {
"id": "2001",
"qualifier": "Organization/United States/Metropolitan Plant/Machine Shop"
}
},
"attributes": [
{
"key": "LOCATION_NAME",
"rawValue": "Machine Shop 256",
"value": "Machine Shop 256"
},
{
"key": "LOCATION_ADDRESS",
"rawValue": "1234 West Main Street, West Boylston, MA 01234",
"value": "1234 West Main Street, West Boylston, MA 01234"
}
],
"children": [],
"summaryListDisplay": [],
"rootEntity": "LOCATION",
"customProperties": {}
},
...
],
"summaryListDisplay": [],
"rootEntity": "ROOT",
"customProperties": {}
}
}
Next steps
Proceed to the Complex queries topic for a look at more complex Retrieve Data requests.
Updated almost 2 years ago