2021-05-03 - DynamoDB pagination: Difference between revisions
Jump to navigation
Jump to search
(Created page with "NPM module - izara-shared 2021-05-03 2021-05-03") |
No edit summary |
||
Line 1: | Line 1: | ||
[[NPM module - izara-shared]] | [[NPM module - izara-shared]] | ||
= Ideas = | |||
* can use Limit to test pagination | |||
https://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Query.html#DDB-Query-request-Limit | |||
* [[NPM module - izara-shared#dynamodbSharedLib.query]] returns queryDetails which states whether more pages/results exist | |||
* we need to consider all Query requests, can they hit limit and paginate? How do we handle, eg: | |||
# We can restrict the number of records, eg we can use UserLimits to allow only 1000 NotificationGroups per user, and can trust Query will never exceed Dynamo pagination limit | |||
# One script can keep requesting from Dynamo until all records received -> danger of script exceeding resources if no limit on number of records | |||
# Use async flow to process parts of the logic in sections *this is the stronger method for large result sets | |||
* if data . Maybe have a timestamp for any sets of data, send the last "limit" and data timestamp on to next lambda invocation, it can check the timestamp to make sure data is still the same.. | |||
[[Category:Working documents| 2021-05-03]] | [[Category:Working documents| 2021-05-03]] | ||
[[Category:Working documents - izara-shared| 2021-05-03]] | [[Category:Working documents - izara-shared| 2021-05-03]] |
Revision as of 12:09, 3 May 2021
Ideas
- can use Limit to test pagination
- NPM module - izara-shared#dynamodbSharedLib.query returns queryDetails which states whether more pages/results exist
- we need to consider all Query requests, can they hit limit and paginate? How do we handle, eg:
- We can restrict the number of records, eg we can use UserLimits to allow only 1000 NotificationGroups per user, and can trust Query will never exceed Dynamo pagination limit
- One script can keep requesting from Dynamo until all records received -> danger of script exceeding resources if no limit on number of records
- Use async flow to process parts of the logic in sections *this is the stronger method for large result sets
- if data . Maybe have a timestamp for any sets of data, send the last "limit" and data timestamp on to next lambda invocation, it can check the timestamp to make sure data is still the same..