REST API - how page by page loading works in detail? What is result order?
We load big number of RTC WorkItems page by page (one page contains 100 records), by following URLs:
- 1st: jazz/rpt/repository/workitem?fields=workitem/workItem[creationDate > 2013-03-01T00:00:00.000-0500]/(id|creator/(name|userId)|creationDate|summary|description))))&size=100&pos=0
-
2nd: jazz/rpt/repository/workitem?fields=workitem/workItem[creationDate > 2013-03-01T00:00:00.000-0500]/(id|creator/(name|userId)|creationDate|summary|description))))&size=100&pos=100&ID=XXXXXX
(id=XXXXXX is from URL given inside 1st response)
- 3rd: ...
-
...
- What is meaning of ID parameter? Does it open an atomic transaction for next calls? Or any other advantage?
-
What is order of returned WorkItems? What if a new WorkItem is added between 2 HTTP calls - can it shift global WorkItem list so actually some other WorkItem can be then loaded twice (in 2 pages)?
-
When WorkItem is changed while calling HTTP calls mentioned above - does it return updated WorkItem content? Similar with newly created WorkItem.
Accepted answer
I'm not an RTC developer so I only state from my experience and observation.
1. The ID should refer to a "query cache". The query should be sent to the database only once, and the server keeps the query result in cache. When you request the next page of the query, the server will pick up items from the cache, not send the query to the database again.
2. The result appears to be order by work item ID - the reportable REST API does not explicitly specify any order parameters. Not sure what you mean by "global WorkItem list". If you mean the result set, it should remain constant, unless (see below).
3. If a work item gets changed, the current attributes are returned when you load the page - it appears that the query cache only holds the work item IDs.
4. If a work item is created after the query is executed, it will not appear in the query result if you refer to the existing query (with the ID).
5. HOWEVER, if a work item is deleted, it will be removed from the query result. I have not done extensive testing to see how it will affect the ordering and pagination of the query result.
1. The ID should refer to a "query cache". The query should be sent to the database only once, and the server keeps the query result in cache. When you request the next page of the query, the server will pick up items from the cache, not send the query to the database again.
2. The result appears to be order by work item ID - the reportable REST API does not explicitly specify any order parameters. Not sure what you mean by "global WorkItem list". If you mean the result set, it should remain constant, unless (see below).
3. If a work item gets changed, the current attributes are returned when you load the page - it appears that the query cache only holds the work item IDs.
4. If a work item is created after the query is executed, it will not appear in the query result if you refer to the existing query (with the ID).
5. HOWEVER, if a work item is deleted, it will be removed from the query result. I have not done extensive testing to see how it will affect the ordering and pagination of the query result.
Comments
Thanks much for quick answer!
- "query cache" - sounds good! We load about 150 000 work items (will be even more), but if it caches WorkItemIDs only, it sounds real.
-
Unfortunately not - it is not sorted by work item ID when I call our URLs mentioned above. But if result set is stable, it is not important then.
- I understand, thanks.
- Good, thanks.
-
Ups, it is possible to delete WorkItems? I am not able to delete them... Who can do it? Is it common use case?
Deleting work items is not a common use case. In fact, many users have a hard time finding out who deleted their work items - currently there is no logging at all. So unless you have a need for such use case, do not give the permission to anybody. By default, no roles have the Delete Work Item permission.