Using Fields in the REST API
You can control the type and amount of data that gets returned from requests to the following REST API endpoints:
Get Users on Site
Query Datasources
Query Views for Site
Query Workbooks for Site
Query Projects
Query Jobs
Query Groups
Get Favorites for user
List Metrics for Site
Fields are the named elements and attributes associated with Tableau Server resources, such as workbooks, data sources, projects, views, and owners. For example, the fields of the workbooks
resource includes the workbook id
, the workbook name
. Depending upon the resource, the fields can include additional attributes and elements for child or sub-resources, such as the project name (project.name
) and id (project.id
), and description (project.description
), .or owner attributes, and tags .
By default, methods like Query Workbooks for Site return information about all of the workbooks on a Tableau Server site. If you are only interested in a subset of these, for example the names of the workbooks, you could search through the response data for the workbook names. But if there are a large number of workbooks, you could be looking through pages of data. You could filter the response data by using filtering and sorting, but that requires that you know what the names are to setup the filters. Starting in REST API 2.5 (Tableau 10.2), you can add field expressions to the query string of the URI. By adding a field expression, you can tailor the response to return only the data for the resource elements you are interested in.
You add a field expression as a query string using the following general format:
<URI>?fields=<field-expression>
For example, you could use a field expression to query a Tableau Server for the just the names of the workbooks:
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/workbooks?fields=name
In this case, the method queries a Tableau Server site and only the names of workbooks are returned in the response packet.
<tsResponse http://tableau.com/api/ts-api-2.5.xsd"> <pagination pageNumber="1" pageSize="100" totalAvailable="11" /> <workbooks> <workbook name="Superstore" /> <workbook name="Regional" /> <workbook name="Backgrounder" /> <workbook name="ClusterController" /> <workbook name="Config" /> <workbook name="VizqlServer" /> <workbook name="Netstat" /> <workbook name="Apache" /> <workbook name="VizqlDesktop" /> </workbooks> </tsResponse>
You can create field expressions to use with a set of REST API query methods for Tableau Server resources. The resources are workbooks, data sources, views, and users. Each resource has a set of fields (for example, the name or id of a workbook or owner. In addition, each resource can contain additional elements (or sub-resources). For example, a workbook contains project resource. You can combine fields and resources to create complex field expressions. For example, you can query for the names of all the workbooks and the names of the projects associated with those workbooks.
Field expression syntax
A field expression has the following syntax:
fields=[keyword,][field, | resource, | resource.field,]...
.
Note: Field names, keywords, and resources are case sensitive.
keyword
(Optional) The keyword
option can take two values. If you do not specify a field expression with your query, the response returns a default set of fields. If specified, the keyword
must appear as the first value in the field expression.
Keyword | Description |
---|---|
_all_ | Returns all the available fields for the requested resource and any additional nested-resources. You can use this value to determine what the available fields are for a given resource. |
_default_ | Returns the default fields for the requested resource and the default fields for any additional nested resources. The default fields are the same fields that are returned by the query method before any field expression is added. You can combine the _default_ keyword in field expressions with additional fields or resources to return all the default fields and ones that are not part of the default set (for example, Fields=_default_,owner.name ). |
field
Specifies the element of the resource that should be returned from the query. The fields that are available depend upon the method and resource that is the object of the query, and whether the query keyword
asks for all fields (_all_)
or the default fields (_default_
).
resource
Specifies the additional (or nested) resource that should be returned from the query. The additional resources depend upon the method and resource that is the object of the query, and whether the query keyword
asks for all fields (_all_)
or the default fields (_default_
). You do not need to specify the resource already queried by the method. For example, if you use Query Workbooks for Site, you do not need to specify workbook
as a resource.
The following table shows the fields and resources that are available for the currently supported endpoints. The default fields and resources are included when you call the method
without a field expression, or when you specify the keyword _default_
in the field expression. Additional fields are returned when you use the _all_
keyword in the field expression.
To specify fields for the supported resources, you use the dot notation, for example, project.id
or owner.siteRole
.
To specify non-default fields that are elements of a resource, such as the name of the owner of a project or the id of a workbook containing a specified view,
you can combine the default keyword with additional fields to return just the information you are interested in (for example, ?fields=_default_,owner.name
)
Query Datasources Fields | |||||
Datasource Use either:
| Owner Use:
| Project Use:
| |||
Get Users on Site Fields | |||||
User Use either:
For servers configured with | | ||||
Query Views for Site Fields | |||||
View Use either:
| Workbook Use:
| Owner Use:
| Project Use:
| ||
Query Workbooks for Site Fields | |||||
Workbook Use either:
| Owner Use:
| Project Use:
| |||
Query Projects Fields | |||||
Project Use either:
| Owner Use:
| Contents Counts Use:
| |||
Query Jobs Fields (Fields in bold face are included in the response by default.) | |||||
Background Job Use either:
| |||||
Query Groups Fields (Fields in bold face are included in the response by default.) | |||||
Group Use either:
| |||||
Get Favorites for user Fields (Fields in bold face are included in the response by default.) | |||||
Favorites Use either:
| Datasource Use:
| Project Use:
| User Use:
user.id
| Workbook Use:
workbook.id
| View Use:
|
List metrics for site Fields (Fields in bold face are included in the response by default.) | |||||
Metrics Use either:
| Owner Use:
| project Use:
|
You can combine field expressions with filtering and sorting to further refine the data you want returned from the method. For example, you can filter on the date a workbook was last updated and then combine that with the field expression to return just the names of the workbooks that meet that criteria. You combine expressions using an ampersand (&). The URI and query string to return workbook names that were updated after a specified date might look like the following:
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/workbooks?filter=updatedAt:gte:2016-10-27T00:49:27Z&fields=name
Note that the fields supported by the ?filter=
and ?sort=
expressions might differ from the fields and resources that you can use in ?fields=
expressions. For information about the fields that can be used for filtering and sorting see, Filtering and Sorting in the Tableau REST API.
Example 1: The following URI shows the query to return just the id of the workbooks on the Tableau Server.
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/workbooks?fields=id
Example 2: The following example returns the default fields and the additional specified fields (owner name, project description) for the resource workbooks.
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/workbooks?fields=_default_,owner.name,project.description
Example 3: The following example returns the name of the workbooks and the default fields for the projects associated with the workbooks. In this case, the default fields are the project name and id. Because this URI queries the workbook resource, it is not necessary to specify workbook.name
. You could also use ?fields=name
.
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/workbooks?fields=workbook.name,project
Example 4: The following example combines the field expression and sorting. The query returns the names and usage data of the views and sorts the response by the workbook name.
http://localhost/api/2.5/sites/1a10f5b9-029b-43e4-a620-773d1690338c/views?fields=name,usage&sort=name:asc