DynamoDB - Агрегация
DynamoDB не предоставляет функций агрегирования. Вы должны творчески использовать запросы, сканирование, индексы и различные инструменты для выполнения этих задач. При этом затраты на выполнение запросов / сканирований в этих операциях могут быть значительными.
У вас также есть возможность использовать библиотеки и другие инструменты для предпочитаемого вами языка программирования DynamoDB. Перед использованием убедитесь, что они совместимы с DynamoDB.
Рассчитать максимум или минимум
Используйте порядок хранения результатов по возрастанию / убыванию, параметр Limit и любые параметры, которые задают порядок для поиска максимального и минимального значений.
Например -
Map<String, AttributeValue> eaval = new HashMap<>();
eaval.put(":v1", new AttributeValue().withS("hashval"));
queryExpression = new DynamoDBQueryExpression<Table>()
.withIndexName("yourindexname")
.withKeyConditionExpression("HK = :v1")
.withExpressionAttributeValues(values)
.withScanIndexForward(false); //descending order
queryExpression.setLimit(1);
QueryResultPage<Lookup> res =
dynamoDBMapper.queryPage(Table.class, queryExpression);
Рассчитать количество
Использовать DescribeTableчтобы получить количество элементов таблицы, обратите внимание, что он предоставляет устаревшие данные. Также используйте JavagetScannedCount method.
Использовать LastEvaluatedKey чтобы обеспечить все результаты.
Например -
ScanRequest scanRequest = new ScanRequest().withTableName(yourtblName);
ScanResult yourresult = client.scan(scanRequest);
System.out.println("#items:" + yourresult.getScannedCount());
Расчет среднего и суммы
Используйте индексы и запрос / сканирование для извлечения и фильтрации значений перед обработкой. Затем просто обработайте эти значения через объект.